您的位置:首页 > 房产 > 建筑 > 嘉兴seo外包_网络营销的职能_百度下载老版本_企业网站制作开发

嘉兴seo外包_网络营销的职能_百度下载老版本_企业网站制作开发

2025/1/10 19:04:30 来源:https://blog.csdn.net/u013261578/article/details/144956035  浏览:    关键词:嘉兴seo外包_网络营销的职能_百度下载老版本_企业网站制作开发
嘉兴seo外包_网络营销的职能_百度下载老版本_企业网站制作开发

1.Agent的基本概念

从软件工程的角度来看,大模型Agent是指基于大语言模型的,能使用工具与外部世界进行交互的计算机程序。

在不同的翻译场景中,Agent可以翻译为智能体、代理、智能助手等,本文中提到的“智能体”即是Agent。
在这里插入图片描述

2.为什么使用 Agent

一些同事希望答疑机器人能具备这样一种功能:只需说出“帮我请明天的假”,机器人便能自动提交请假申请单。

为实现此功能,答疑机器人的设计可以包括以下步骤:

1.编写工具函数,利用公司内部的API实现请假等操作;
2.当大模型接收到用户的指令(如“我要请后天的假”)时,解析出需要调用的工具及其参数,例如请假工具所需的日期;
3.根据大模型的解析结果,执行相应的工具函数,并获取结果,例如“2025年x月x日至2025年y月y日的请假申请已提交”。然后直接或经过处理后将结果反馈给用户。 这种增添了工具函数的系统被称为Agent。它作为大模型与外界互动的桥梁,扩展了大模型的功能。

在这里插入图片描述

3.构建 Agent 的基本流程

3.1.定义工具函数

3.1.1 查询员工信息

def query_employee_info(query):'''输入用户提问,输出员工信息查询结果'''# 1. 首先根据用户提问,使用NL2SQL生成SQL语句llm = DashScope(model_name="qwen-plus")messages = [ChatMessage(role=MessageRole.SYSTEM, content='''你有一个表叫employees,记录公司的员工信息,这个表有department(部门)、name(姓名)、HR三个字段。你需要根据用户输入生成sql语句进行查询,你一定不能生成sql语句之外的内容,也不要把```sql```这个信息加上。'''),ChatMessage(role=MessageRole.USER, content=query)]SQL_output = llm.chat(messages).message.content# 打印出SQL语句print(f'SQL语句为:{SQL_output}')# 2. 根据SQL语句去查询数据库(此处为模拟查询),并返回结果if SQL_output == "SELECT COUNT(*) FROM employees WHERE department = '教育部门'":return "教育部门共有66名员工。"if SQL_output == "SELECT HR FROM employees WHERE name = '张三'":return "张三的HR是李四。"if SQL_output == "SELECT department FROM employees WHERE name = '王五'":return "王五的部门是后勤部。"else:return "抱歉,我暂时无法回答您的问题。"

3.1.2 发送请假申请

def send_leave_application(date):'''输入请假时间,输出请假申请发送结果'''return f'已为你发送请假申请,请假日期是{date}。'

3.1.3 查询公司规章制度

def query_company_info(query):'''输入用户提问,输出公司信息查询结果'''# 使用封装好的函数加载索引index = load_index()query_engine = index.as_query_engine(llm=DashScope(model_name="qwen-plus"))return query_engine.query(query).response

3.2将工具函数与大模型集成进Agent中

ChatAssistant = Assistants.create(# 在此指定模型名称model="qwen-plus",# 在此指定Agent名称name='贾维斯',# 在此指定Agent的描述信息description='一个智能助手,能够查询员工信息,帮助员工发送请假申请,或者查询公司规章制度。',# 用于提示大模型所具有的工具函数能力,也可以规范输出格式instructions='''你是贾维斯,你的功能有以下三个:1. 查询员工信息。例如:查询员工张三的HR是谁;2. 发送请假申请。例如:当员工提出要请假时,你可以在系统里帮他完成请假申请的发送;3. 查询公司规章制度。例如:我们公司项目管理的工具是什么?请准确判断需要调用哪个工具,并礼貌回答用户的提问。''',# 将工具函数传入tools=[{# 定义工具函数类型,一般设置为function即可'type': 'function','function': {# 定义工具函数名称,通过map方法映射到query_employee_info函数'name': '查询员工信息',# 定义工具函数的描述信息,Agent主要根据description来判断是否需要调用该工具函数'description': '当需要查询员工信息时非常有用,比如查询员工张三的HR是谁,查询教育部门总人数等。',# 定义工具函数的参数'parameters': {'type': 'object','properties': {# 将用户的提问作为输入参数'query': {'type': 'str',# 对输入参数的描述'description': '用户的提问。'},},# 在此声明该工具函数需要哪些函数'required': ['query']},}},{'type': 'function','function': {'name': '发送请假申请','description': '当需要帮助员工发送请假申请时非常有用。','parameters': {'type': 'object','properties': {# 需要请假的时间'date': {'type': 'str','description': '员工想要请假的时间。'},},'required': ['date']},}},{'type': 'function','function': {'name': '查询公司规章制度','description': '当需要查询公司规章制度时非常有用,比如查询公司项目管理的工具是什么,查询公司都有哪些部门等。','parameters': {'type': 'object','properties': {'query': {'type': 'str','description': '用户的提问。'}}}}}]
)
print(f'{ChatAssistant.name}创建完成')
# 建立Agent Function name与工具函数的映射关系
function_mapper = {"查询员工信息": query_employee_info,"发送请假申请": send_leave_application,"查询公司规章制度": query_company_info
}
print('工具函数与function.name映射关系建立完成')

3.3 完整代码:

firstAgent.py

# 1. 环境配置
import os
# 获取dashscope的api key
DASHSCOPE_API_KEY = os.getenv("DASHSCOPE_API_KEY")# 设置代理
os.environ["http_proxy"] = "http://127.0.0.1:4780"
os.environ["https_proxy"] = "http://127.0.0.1:4780"# 禁用nltk下载
os.chdir(os.path.dirname(__file__))
os.environ['NLTK_DATA'] = './nltk_cache'# 2. 导入依赖
from llama_index.llms.dashscope import DashScope
from llama_index.core.base.llms.types import MessageRole, ChatMessage
from chatbot.rag import load_index
from dashscope import Assistants, Messages, Runs, Threads
import json# 3. 核心工具函数
def query_employee_info(query):'''输入用户提问,输出员工信息查询结果'''# 1. 首先根据用户提问,使用NL2SQL生成SQL语句llm = DashScope(model_name="qwen-plus")messages = [ChatMessage(role=MessageRole.SYSTEM, content='''你有一个表叫employees,记录公司的员工信息,这个表有department(部门)、name(姓名)、HR三个字段。你需要根据用户输入生成sql语句进行查询,你一定不能生成sql语句之外的内容,也不要把```sql```这个信息加上。'''),ChatMessage(role=MessageRole.USER, content=query)]SQL_output = llm.chat(messages).message.content# 打印出SQL语句print(f'SQL语句为:{SQL_output}')# 2. 根据SQL语句去查询数据库(此处为模拟查询),并返回结果if SQL_output == "SELECT COUNT(*) FROM employees WHERE department = '教育部门'":return "教育部门共有66名员工。"if SQL_output == "SELECT HR FROM employees WHERE name = '张三'":return "张三的HR是李四。"if SQL_output == "SELECT department FROM employees WHERE name = '王五'":return "王五的部门是后勤部。"else:return "抱歉,我暂时无法回答您的问题。"def send_leave_application(date):'''输入请假时间,输出请假申请发送结果'''return f'已为你发送请假申请,请假日期是{date}。'def query_company_info(query):'''输入用户提问,输出公司信息查询结果'''# 使用封装好的函数加载索引index = load_index()query_engine = index.as_query_engine(llm=DashScope(model_name="qwen-plus"))return query_engine.query(query).response# 4. Agent定义和配置
ChatAssistant = Assistants.create(# 在此指定模型名称model="qwen-plus",# 在此指定Agent名称name='贾维斯',# 在此指定Agent的描述信息description='一个智能助手,能够查询员工信息,帮助员工发送请假申请,或者查询公司规章制度。',# 用于提示大模型所具有的工具函数能力,也可以规范输出格式instructions='''你是贾维斯,你的功能有以下三个:1. 查询员工信息。例如:查询员工张三的HR是谁;2. 发送请假申请。例如:当员工提出要请假时,你可以在系统里帮他完成请假申请的发送;3. 查询公司规章制度。例如:我们公司项目管理的工具是什么?请准确判断需要调用哪个工具,并礼貌回答用户的提问。''',# 将工具函数传入tools=[{# 定义工具函数类型,一般设置为function即可'type': 'function','function': {# 定义工具函数名称,通过map方法映射到query_employee_info函数'name': '查询员工信息',# 定义工具函数的描述信息,Agent主要根据description来判断是否需要调用该工具函数'description': '当需要查询员工信息时非常有用,比如查询员工张三的HR是谁,查询教育部门总人数等。',# 定义工具函数的参数'parameters': {'type': 'object','properties': {# 将用户的提问作为输入参数'query': {'type': 'str',# 对输入参数的描述'description': '用户的提问。'},},# 在此声明该工具函数需要哪些函数'required': ['query']},}},{'type': 'function','function': {'name': '发送请假申请','description': '当需要帮助员工发送请假申请时非常有用。','parameters': {'type': 'object','properties': {# 需要请假的时间'date': {'type': 'str','description': '员工想要请假的时间。'},},'required': ['date']},}},{'type': 'function','function': {'name': '查询公司规章制度','description': '当需要查询公司规章制度时非常有用,比如查询公司项目管理的工具是什么,查询公司都有哪些部门等。','parameters': {'type': 'object','properties': {'query': {'type': 'str','description': '用户的提问。'}}}}}]
)
print(f'{ChatAssistant.name}创建完成')
# 建立Agent Function name与工具函数的映射关系
function_mapper = {"查询员工信息": query_employee_info,"发送请假申请": send_leave_application,"查询公司规章制度": query_company_info
}
print('工具函数与function.name映射关系建立完成')# 5. Agent响应处理
def get_agent_response(assistant, message=''):# 打印出输入Agent的信息thread = Threads.create()message = Messages.create(thread.id, content=message)run = Runs.create(thread.id, assistant_id=assistant.id)run_status = Runs.wait(run.id, thread_id=thread.id)# 如果响应失败,会打印出run failedif run_status.status == 'failed':print('run failed:')# 如果需要工具来辅助大模型输出,则进行以下流程if run_status.required_action:f = run_status.required_action.submit_tool_outputs.tool_calls[0].function# 获得function namefunc_name = f['name']# 获得function 的入参param = json.loads(f['arguments'])# 打印出工具信息print("function is",f)# 根据function name,通过function_mapper映射到函数,并将参数输入工具函数得到output输出if func_name in function_mapper:output = function_mapper[func_name](**param)else:output = ""tool_outputs = [{'output':output}]run = Runs.submit_tool_outputs(run.id,thread_id=thread.id,tool_outputs=tool_outputs)run_status = Runs.wait(run.id, thread_id=thread.id)run_status = Runs.get(run.id, thread_id=thread.id)msgs = Messages.list(thread.id)# 将Agent的输出返回return msgs['data'][0]['content'][0]['text']['value']# 6. 测试函数
def test_three_tools():query_employee_info("教育部门有几个人")print(send_leave_application("明后两天"))print(query_company_info("我们公司项目管理应该用什么工具"))# 7. 主函数测试
if __name__ == "__main__":# test_three_tools()query_stk = ["谁是张三的HR?","教育部门一共有多少员工?","王五在哪个部门?","帮我提交下周三请假的申请","我们公司应该用什么项目管理工具呢?"]for query in query_stk:print("提问是:")print(query)print("思考过程与最终输出是:")print(get_agent_response(ChatAssistant,query))print("\n")

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com