news 2026/5/23 17:38:50

通义千问的 Function Call - demo学习

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
通义千问的 Function Call - demo学习

1、理解 Function Call

让大模型能调用外部工具、函数,而非仅靠自身知识库回答问题。

2、流程步骤:

用户提问→模型判断调用函数→执行自定义函数→模型基于函数结果生成回答

第一调用模型
让模型分析用户问题,判断是否需要调用函数,并返回调用函数指令

第二次调用模型
把自定义函数执行的结果传给模型,模型基于真实数据生成自然语言回答(比如 “大连当前温度 10 摄氏度,晴天,微风”)

3、代码

# 导入JSON模块:用于序列化/反序列化函数参数和返回结果 import json # 导入操作系统模块:读取环境变量中的API密钥 import os # 导入通义千问SDK核心模块 import dashscope # 从环境变量读取API密钥并配置 dashscope.api_key = os.environ.get('DASHSCOPE_API_KEY') # 定义天气查询函数:模拟返回指定城市的天气(核心业务函数) def get_current_weather(location, unit="摄氏度"): # 初始化温度(默认-1表示未匹配城市) temperature = -1 # 按城市匹配模拟温度 if '大连' in location: temperature = 10 if '上海' in location: temperature = 36 if '深圳' in location: temperature = 37 # 构造天气信息字典并转为JSON字符串返回(符合Function Call格式要求) return json.dumps({ "location": location, "temperature": temperature, "unit": unit, "forecast": ["晴天", "微风"] }) # 封装模型调用函数 def call_qwen(messages): try: # 调用通义千问qwen-max模型,指定函数列表和返回格式 return dashscope.Generation.call( model='qwen-max', messages=messages, functions=functions, result_format='message' # 结构化消息格式,便于解析函数调用 ) except Exception as e: # 捕获异常并打印,返回None标识调用失败 print(f"API调用异常: {str(e)}") return None # 核心对话逻辑:实现"提问→判断调用函数→执行函数→生成最终回答" def weather_qa(): # 1. 初始化用户问题和消息上下文(大模型对话必须的格式:role+content) messages = [{"role": "user", "content": "大连的天气怎样"}] # 2. 第一次调用模型:判断是否需要调用函数 response = call_qwen(messages) # 校验响应有效性,失败则直接返回 if not response or not response.output: return "模型响应失败" # 提取模型返回的核心消息 assistant_msg = response.output.choices[0].message # 将模型消息加入上下文(保证对话连贯性) messages.append(assistant_msg) # 3. 判断模型是否要求调用函数 if hasattr(assistant_msg, 'function_call') and assistant_msg.function_call: # 解析函数调用参数(JSON字符串转字典) args = json.loads(assistant_msg.function_call['arguments']) # 执行天气查询函数,获取结果 weather_result = get_current_weather( location=args.get('location'), unit=args.get('unit', '摄氏度') # 设默认值,避免参数缺失 ) # 构造函数调用结果消息(必须按role=function格式) function_msg = { "role": "function", "name": assistant_msg.function_call['name'], "content": weather_result } # 将函数结果加入上下文 messages.append(function_msg) # 4. 第二次调用模型:基于函数结果生成最终回答 final_response = call_qwen(messages) if final_response and final_response.output: return final_response.output.choices[0].message.content # 若无需调用函数,直接返回模型初始回答 return assistant_msg.content # 定义函数调用描述(核心:告诉模型可调用的函数及参数规则) functions = [{ 'name': 'get_current_weather', # 必须和自定义函数名一致 'description': '获取指定城市的当前天气', # 改为中文描述,更适配中文提问 'parameters': { 'type': 'object', 'properties': { 'location': { 'type': 'string', 'description': '城市名称,例如:大连、上海' # 中文示例更直观 }, 'unit': {'type': 'string', 'enum': ['摄氏度', '华氏度']} # 改为中文枚举值 }, 'required': ['location'] # 必填参数:location } }] # 主程序入口 if __name__ == "__main__": # 执行问答逻辑并打印最终结果 print("最终回答:", weather_qa())
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/14 2:34:11

终于见到真机!原子重塑12喷嘴3D打印机来了

2026年1月6日至9日,国际消费电子展(CES 2026)在美国拉斯维加斯如期举办。作为消费级3D打印赛道的后起之秀,原子重塑正式在展会现场发布了其全新多头桌面3D打印机Palette 300,吸引了不少观众驻足围观。Palette 300配备了…

作者头像 李华
网站建设 2026/5/22 21:32:32

AI助力SKYWALKING:自动化监控与性能优化

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个基于SKYWALKING的AI辅助监控系统,能够自动分析应用性能数据,识别潜在问题并提供优化建议。系统应支持实时监控、异常检测、根因分析和性能优化建议…

作者头像 李华
网站建设 2026/5/21 7:48:31

从博客学习到实战落地:M2FP帮助开发者跨越最后一公里

从博客学习到实战落地:M2FP帮助开发者跨越最后一公里 🧩 M2FP 多人人体解析服务 (WebUI API) 📖 项目简介 在计算机视觉领域,人体解析(Human Parsing) 是一项关键的细粒度语义分割任务,目标是将…

作者头像 李华
网站建设 2026/5/14 1:06:27

LingoNaut 语言助手

原文:towardsdatascience.com/lingonaut-language-assistant-6abe3e8b045c?sourcecollection_archive---------3-----------------------#2024-02-11 使用 Ollama-Python 对讲机进行多语言学习 https://natecibik.medium.com/?sourcepost_page---byline--6abe3e8…

作者头像 李华
网站建设 2026/5/21 3:20:15

MGeo模型对英文混合地址的处理能力

MGeo模型对英文混合地址的处理能力 引言:地址相似度匹配的现实挑战与MGeo的定位 在全球化业务场景中,跨语言、跨区域的地址数据融合已成为电商、物流、地图服务等领域的核心痛点。尤其是在跨国订单匹配、用户画像整合、门店信息去重等任务中,…

作者头像 李华
网站建设 2026/5/12 20:17:57

传统模型解释 vs SHAP分析:效率对比实验

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个对比分析项目,比较SHAP与传统模型解释方法的效率。要求:1) 在同一数据集上应用多种解释方法;2) 记录各方法的计算时间和内存消耗&#…

作者头像 李华