当前位置: 首页 > article >正文

如何基于OpenAI进行Function Calling调用

基于LLM进行工具调用或技能执行是近期最热门的话题之一。目前已经有很多LLM工具调用框架比如langchain、openclaw、owl等。然而工具调用过程一般被封装在框架内用户一般只能接触到各种配置窥探不到调用细节。这里尝试基于网络资料模拟获取天气的函数示例如何利用LLM进行Function Calling的过程。1 环境准备1.1 安装openai如果尚未安装首先安装 OpenAI 库。pip install openai1.2 配置openai然后在代码中设置LLM的 API Key、Base Url示例代码如下。import os model_name gpt_model_name # LLM名称,比如deepseek-r1, qwen3.5-8b os.environ[OPENAI_API_KEY] gpt_api_key # LLM供应商提供的api key os.environ[OPENAI_BASE_URL] gpt_api_url # LLM供应商提供llm访问api的url2 工具准备由于是模拟一个获取天气的函数让模型在需要时调用它。所以在实际模拟之前需要定义工具和实现函数。2.1 定义可用的工具定义可用工具在这里即指定义Function。需要以 JSON 格式描述函数包括函数名、描述和参数。这里定义一个获取城市天气的函数tools [ { type: function, function: { name: get_weather, description: 获取指定城市的当前天气信息, parameters: { type: object, properties: { city: { type: string, description: 城市名称例如北京、上海 }, unit: { type: string, enum: [celsius, fahrenheit], description: 温度单位默认为摄氏度 } }, required: [city] } } } ]2.2 实现函数逻辑这里通过字典实现一个及其简单的示例函数模拟简单模拟返回一个字符串。示例代码如下def get_weather(city, unitcelsius): # 模拟天气数据 weather_data { 北京: {celsius: 18°C 晴, fahrenheit: 64°F 晴}, 上海: {celsius: 22°C 多云, fahrenheit: 72°F 多云}, } info weather_data.get(city, {}).get(unit, 未知城市或单位) return f{city}当前天气{info}实际应用中这里可以调用真实的天气 API。3 调用示例3.1 工具对话示例这里发起带有 tools 的对话请求发送用户消息模型可能会决定是否调用函数。对话示例代码如下。from openai import OpenAI # 2. 初始化客户端 client OpenAI() def chat_with_function(): messages [{role: user, content: 北京今天天气怎么样}] response client.beta.chat.completions.create( modelmodel_name, # 或 gpt-4-turbo 等支持 function calling 的模型 messagesmessages, toolstools, tool_choiceauto, # 让模型自动决定是否调用函数 ) # 获取模型的响应 response_message response.choices[0].message print(初始响应:, response_message) # 检查是否有工具调用请求 if response_message.tool_calls: # 将模型的响应添加到对话历史 messages.append(response_message) # 遍历所有工具调用 for tool_call in response_message.tool_calls: function_name tool_call.function.name arguments json.loads(tool_call.function.arguments) if function_name get_weather: # 调用我们实际的函数 result get_weather(**arguments) # 将函数执行结果作为消息返回 messages.append({ role: tool, tool_call_id: tool_call.id, content: result, }) # 再次请求模型将工具返回结果传递给模型获得最终回答 second_response client.beta.chat.completions.create( modelmodel_name, messagesmessages, toolstools, ) final_message second_response.choices[0].message.content print(最终回答:, final_message) else: # 没有工具调用直接输出内容 print(回答:, response_message.content) # 执行 chat_with_function()以下是运行结果示例初始响应: ChatCompletionMessage(contentNone, refusalNone, roleassistant, annotationsNone, audioNone, function_callNone, tool_calls[ChatCompletionMessageFunctionToolCall(idchatcmpl-tool-8078c38xxxxxxx, functionFunction(arguments{city: 北京}, nameget_weather), typefunction)], reasoning用户询问北京今天的天气情况。我需要使用 get_weather 工具来获取北京的天气信息。\n\n根据工具定义\n- city 参数是必需的用户已经提供了北京\n- unit 参数是可选的默认是摄氏度用户没有特别指定所以使用默认值\n\n我应该调用 get_weather 函数参数 city 设为北京。\n)最终回答:北京今天天气晴朗当前气温为18°C。是个不错的天气适合外出活动示例完整展示了Function Calling的基本流程可根据业务需求扩展更多函数和更复杂的逻辑。3.2 关键点说明这里给出上述调用过程需要注意的一些地方。1工具描述这里通过通过tools参数告知模型有哪些可用函数描述要清晰参数要准确。2模型决策这里设置 tool_choiceauto让模型自主判断是否需要调用函数。也可以强制调用某个函数如 {type: function, function: {name: get_weather}}。3处理响应模型返回的tool_calls中包含了要调用的函数名和参数执行后需要将结果以role: tool的形式追加到对话历史并再次请求模型以获得最终自然语言回答。4支持多轮如果一次响应中有多个工具调用可以依次执行并汇总结果。reference---OpenAI Function Call Streaming Examplehttps://pkg.go.dev/github.com/tmc/langchaingo/examples/openai-function-call-streaming-example#section-readmeOpenAI 函数调用上手示例大全https://docs.kanaries.net/zh/articles/openai-function-calling大模型Function Call案例实战https://bbs.huaweicloud.com/blogs/475486

相关文章:

如何基于OpenAI进行Function Calling调用

基于LLM进行工具调用或技能执行,是近期最热门的话题之一。 目前已经有很多LLM工具调用框架,比如langchain、openclaw、owl等。 然而,工具调用过程一般被封装在框架内,用户一般只能接触到各种配置,窥探不到调用细节。…...

构建编译环境

拉取LLVM并配置这里我保存在D盘#创建文件夹 mkdir D:\LLVM cd D:\LLVM #拉取源码 (只拉取核心仓库,不需要 submodule,现在 LLVM 是 monorepo) #这一步比较大,网络不好请挂梯子 git clone --depth1 https://github.com/llvm/llvm-project.…...

仅用200行代码重构内存管理模块:某AI平台将GPU服务器月成本压至$1,840的独家策略(限时开源)

第一章:Python 智能体内存管理策略Python 的内存管理并非由开发者直接操控,而是由解释器内置的智能体协同完成——包括引用计数、循环垃圾回收器(GC)和内存池机制三者构成动态平衡系统。这一“智能体”在运行时持续感知对象生命周…...

代码分享】“基因集单通路的泛癌GSEA富集分析

【代码分享]基因集单通路的泛癌GSEA富集分析#资料 如图最近在整理TCGA多组学数据时,发现不少小伙伴对通路活性评估有需求。今天分享一个快速实现泛癌GSEA分析的方法,特别适合需要观察某个特定通路在多个癌症类型中激活状态的情况。这个方法不需要复杂的编…...

基于机器学习算法的亚马逊用户评论情感分析研究:深入探讨随机森林与决策树模型的应用及其实验评估

《基于随机森林和决策树的亚马逊用户评论情感分析研究》深入探讨了利用机器学习技术对亚马逊用户评论数据进行情感分析的方法,旨在为电商企业提供更精准的用户反馈处理工具,以辅助产品优化和服务改进 通过采用决策树模型和随机森林模型这两种不同的机器学…...

工业冷水机控制程序西门子1200plc含压缩机,电子膨胀阀控制策略,饱和温度计算公式

工业冷水机控制程序西门子1200plc含压缩机,电子膨胀阀控制策略,饱和温度计算公式凌晨三点钟的冷水机组房,设备轰鸣声中闪烁着PLC运行指示灯。手指划过TP1200触摸屏的瞬间,压缩机启动电流曲线在屏幕上划出漂亮的爬坡轨迹——这就是…...

TI SAR ADC模型(Matlab) 包含各类非理想因素,时钟偏差,增益偏差

TI SAR ADC模型(Matlab) 包含各类非理想因素,时钟偏差,增益偏差,失调偏差 模型参数均可自由设置直接上干货吧,今天聊聊怎么用Matlab折腾带非理想特性的SAR ADC模型。玩过ADC的都知道,现实中的转…...

如何实现 SEO 优化与广告投放的协同效果

如何实现 SEO 优化与广告投放的协同效果 在当今竞争激烈的互联网环境中,实现 SEO 优化与广告投放的协同效果已经成为提升网站流量和销售转化的关键。SEO(搜索引擎优化)和广告投放虽然各自有各自的目标和优势,但它们的结合能够带来…...

飞机喷涂废气治理厂家丨一场看不见的“废气治理战”如何打响?

你有没有注意过,当你透过舷窗望向停机坪时,那些静静停靠的飞机,机身光洁如镜,涂装色彩鲜明?一架飞机交付使用,到每隔数年的定期大修,飞机都需要经历复杂的喷涂过程。这层看似简单的“外衣”&…...

AI 生码:RAG 落地量化实践与体系搭建

一、背景:前端 AI 落地,RAG 成为核心关键 在前端与 AI 融合落地过程中,AI 生成 UI 代码、业务测试用例等核心场景,均依赖知识库能力支撑。当应用进入深水区,RAG(检索增强生成)的选型与优化&…...

Claude Code 源码研究【第二弹】:智能体框架与大模型相互成就

在上一篇“Claude Code 源码研究:一个 while(true) 循环让大模型自己干活”之后,继续我们的研究——01自然语言引导能保证模型每次都听话吗?Claude Code 不靠 if-else 控制模型选哪个工具,而是靠 40 份精心撰写的"工具说明书…...

智能家庭教育:OpenClaw+Phi-3-vision-128k-instruct批改孩子手写作业

智能家庭教育:OpenClawPhi-3-vision-128k-instruct批改孩子手写作业 1. 为什么需要AI作业批改助手 作为一个经常辅导孩子功课的家长,我深刻体会到批改作业的痛点。每天晚上检查数学题时,既要核对答案正确性,又要分析错误原因&am…...

OpenClaw二次开发:基于Qwen3.5-9B定制个性化技能模块

OpenClaw二次开发:基于Qwen3.5-9B定制个性化技能模块 1. 为什么需要自定义技能模块 去年冬天,我发现自己每天早晨都要手动查询天气来决定穿什么衣服。作为一个技术爱好者,我开始思考:能否让OpenClaw自动完成这个任务&#xff1f…...

WarcraftHelper:让魔兽争霸III重获新生的兼容性优化工具

WarcraftHelper:让魔兽争霸III重获新生的兼容性优化工具 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper WarcraftHelper是一款免费开源的魔…...

2026年最新codex 第三方 api 配置指南

真正决定 Codex 能不能顺利进入项目的,通常不是 npm 命令有没有跑完,而是 codex 第三方 api 是否配完整。很多人在 openai/codex 安装结束后马上就碰到 401、请求超时、模型不可用,甚至一直过不了认证,这类问题大多都落在 ~/.code…...

SEO_10个提升网站排名的SEO技巧与实战方法

SEO:10个提升网站排名的SEO技巧与实战方法 在当今数字化时代,网站排名不仅关乎网站的曝光率,更影响到业务的发展。因此,提升网站排名(SEO)成为了每一个网站主的首要任务。有哪些SEO技巧能够帮助提升网站的排名呢&…...

07_Cursor之语言支持与扩展生态

关键字:语言支持, VS Code扩展, 跨平台, Electron, Python开发, 扩展生态 07_Cursor之语言支持与扩展生态 Cursor知识体系 Cursor知识体系(续) | -- 生态支持层 | -- 多语言支持 | | -- 通用LLM支持 | | -- 自动语言检测 | | …...

SEO_ 详解SEO优化中内容与外部链接的建设策略

SEO优化中内容与外部链接的建设策略 在当前互联网营销领域,SEO优化(搜索引擎优化)是提升网站流量和品牌知名度的关键手段。其中,内容与外部链接的建设策略是两大核心要素。本文将详解SEO优化中内容与外部链接的建设策略&#xff…...

OpenClaw家庭相册:Qwen3.5-9B-VL自动识别人物与场景分类

OpenClaw家庭相册:Qwen3.5-9B-VL自动识别人物与场景分类 1. 为什么需要智能相册管理 作为一个摄影爱好者和两个孩子的父亲,我的手机和硬盘里堆积了超过5万张家庭照片。每次想找特定场景(比如"去年夏天在海边的全家福"&#xff09…...

长尾关键词的SEO提交技巧有哪些

长尾关键词的SEO提交技巧有哪些 在当今数字营销的环境中,SEO(搜索引擎优化)是提升网站流量的关键手段之一。而在SEO策略中,长尾关键词(Long-Tail Keywords)的应用尤为重要。长尾关键词通常是由三个或更多的…...

OpenClaw环境隔离方案:Phi-3-vision-128k-instruct多模态任务专用沙箱配置

OpenClaw环境隔离方案:Phi-3-vision-128k-instruct多模态任务专用沙箱配置 1. 为什么需要环境隔离? 去年我在尝试用OpenClaw处理一批包含敏感客户数据的PDF文件时,曾因为一个错误的鼠标操作指令导致系统临时文件被意外删除。那次经历让我意…...

OpenClaw配置文件详解:Qwen3.5-9B高级参数调优手册

OpenClaw配置文件详解:Qwen3.5-9B高级参数调优手册 1. 为什么需要手动调优OpenClaw配置 上周我尝试用OpenClaw自动处理一批技术文档的归档工作,发现同样的任务在不同时段完成速度差异巨大。有时30分钟就能搞定,有时却要卡顿近2小时。这促使…...

Hotkey Detective:定位并解决Windows快捷键冲突的终极方案

Hotkey Detective:定位并解决Windows快捷键冲突的终极方案 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 一、…...

Ubuntu 20.04下Mathematica 12.3安装全攻略(附Jupyter集成技巧)

Ubuntu 20.04下Mathematica 12.3安装与Jupyter集成实战指南 在科研计算与符号数学领域,Mathematica始终保持着不可替代的地位。对于Ubuntu用户而言,安装特定历史版本(如12.3)往往比最新版本更具挑战性——官方默认提供最新版下载&…...

Python 3.14 JIT性能调优进入倒计时:CPython核心组已宣布v3.15将移除--enable-jit-experimental标志,现在不掌握就永久错过

第一章:Python 3.14 JIT编译器的演进脉络与战略意义Python 3.14 并非官方发布的正式版本——截至 2024 年,CPython 最新稳定版为 3.12,3.13 处于预发布阶段,而 3.14 尚未进入开发路线图。因此,“Python 3.14 JIT 编译器…...

WebPlotDigitizer终极指南:从科研图表到结构化数据的完整解决方案

WebPlotDigitizer终极指南:从科研图表到结构化数据的完整解决方案 【免费下载链接】WebPlotDigitizer Computer vision assisted tool to extract numerical data from plot images. 项目地址: https://gitcode.com/gh_mirrors/we/WebPlotDigitizer 在科研和…...

Android开发者的USB摄像头避坑指南:从设备枚举到SurfaceView预览的完整流程

Android开发者实战:USB摄像头集成全流程与疑难解析 去年接手一个医疗设备项目时,我需要在Android平板上接入工业级USB摄像头。本以为三天能搞定,结果光是解决画面拉伸问题就耗了一周。这份踩坑经验总结,将带你系统掌握从设备枚举到…...

Vue2项目里用Cesium加载天地图标注,保姆级避坑指南(含Token申请)

Vue2项目集成Cesium与天地图标注的工程化实践指南 当WebGIS需求遇上Vue技术栈,如何在老项目中优雅地引入三维地图能力?本文将以工程化视角,系统讲解Vue2项目中集成Cesium加载天地图标注的完整技术路径。不同于基础教程,我们将重点…...

OpenClaw内容审核:Qwen3.5-9B-AWQ-4bit实现图片敏感内容过滤

OpenClaw内容审核:Qwen3.5-9B-AWQ-4bit实现图片敏感内容过滤 1. 为什么需要轻量级内容审核方案 作为一个运营过多个UGC平台的技术人,我深知内容审核的痛点。早期我用过商业审核API,但面临三个问题:一是成本高,每千张…...

《QGIS快速入门与应用基础》256:SVG格式:适合矢量图二次编辑

作者:翰墨之道,毕业于国际知名大学空间信息与计算机专业,获硕士学位,现任国内时空智能领域资深专家、CSDN知名技术博主。多年来深耕地理信息与时空智能核心技术研发,精通 QGIS、GrassGIS、OSG、OsgEarth、UE、Cesium、OpenLayers、Leaflet、MapBox 等主流工具与框架,兼具…...