智能体多个工具调用

from langchain.chat_models import init_chat_model

from langchain_core.output_parsers import JsonOutputParser

from langchain_core.prompts import ChatPromptTemplate

from pydantic import BaseModel, Field

from env_utils import DEEPSEEK_API_KEY, DEEPSEEK_BASE_URL

from langchain.agents import create_agent,AgentState

from langchain.agents.middleware import SummarizationMiddleware, before_model, after_model

from langchain_core.messages import ToolMessage

from langchain_core.tools import tool

from langgraph.checkpoint.memory import InMemorySaver

from langgraph.prebuilt import ToolRuntime

from langgraph.prebuilt import ToolRuntime

from langgraph.types import Command

from init_llm import deepseek_llm

大模型使用工具前,需要通过"bind_tools()"方法将工具与模型绑定,让模型能够识别可用工具,绑定后,模型会根据输入内容自动判断是否需要调用工具:

from langchain.tools import tool

from langchain_core.messages import HumanMessage

from init_llm import deepseek_llm

定义股票查询工具

@tool

def get_stock_price(company: str, timeframe: str = "today") -> str:

"""获取指定公司的股票价格信息

Args:

company: 公司名称(如:苹果公司, 微软公司, 谷歌公司)

timeframe: 时间范围(today-今日, week-本周, month-本月)

"""

模拟股票数据

mock_data = {

"苹果公司": {"today": 185.20, "week": 183.50, "month": 180.75},

"微软公司": {"today": 415.86, "week": 412.30, "month": 405.42},

"谷歌公司": {"today": 15.42, "week": 15.20, "month": 14.85}

}

if company in mock_data:

price = mock_data[company].get(timeframe, "未知时间范围")

return f"{company} {timeframe}价格: {price}美元"

else:

return f"未找到股票代码 {company} 的数据"

定义新闻搜索工具

@tool

def search_news(company: str) -> str:

"""搜索指定公司的财经新闻

Args:

company: 公司名称

Return:

公司的财经新闻,每个新闻占一行

"""

模拟新闻数据

mock_news = {

"苹果公司": [

"苹果发布新款iPhone,股价上涨3%",

"苹果与欧盟达成反垄断和解协议",

"苹果将在印度扩大生产规模"

],

"微软公司": [

"微软Azure云业务季度增长超预期",

"微软完成对Nuance的收购",

"微软推出新一代AI助手Copilot"

],

"谷歌公司": [

"谷歌发布新AI模型,性能提升20%",

"谷歌与OpenAI合作,开发新的AI助手",

"谷歌在欧洲展开AI研究项目"

]

}

news_list = mock_news.get(company, [f"未找到{company}的相关新闻"])

return "\n".join(news_list)

agent=create_agent(

model=deepseek_llm,

tools=[get_stock_price, search_news]

)

resp=agent.invoke({"messages":[{"role": "user", "content": "谷歌公司的股价和新闻是什么?"}]})

print(resp)

{'messages': [

HumanMessage(content='谷歌公司的股价和新闻是什么?', additional_kwargs={}, response_metadata={}, id='dca5d4ed-3fc6-479c-87d9-f7379b948656'),

AIMessage(content='我来帮您查询谷歌公司的股价和最新新闻,先获取这两项信息。', additional_kwargs={'refusal': None}, response_metadata={'token_usage': {'completion_tokens': 112, 'prompt_tokens': 410, 'total_tokens': 522, 'completion_tokens_details': None, 'prompt_tokens_details': {'audio_tokens': None, 'cached_tokens': 384}, 'prompt_cache_hit_tokens': 384, 'prompt_cache_miss_tokens': 26}, 'model_provider': 'deepseek', 'model_name': 'deepseek-v4-flash', 'system_fingerprint': 'fp_8b330d02d0_prod0820_fp8_kvcache_20260402', 'id': '2bbec9f3-fe00-4a81-9133-e6083aad7698', 'finish_reason': 'tool_calls', 'logprobs': None}, id='lc_run--019e3030-8a13-7d31-b182-620eef87f117-0', tool_calls=[{'name': 'get_stock_price', 'args': {'company': '谷歌公司', 'timeframe': 'today'}, 'id': 'call_00_hQg6iYmwYKoPEL4zN1me4618', 'type': 'tool_call'}, {'name': 'search_news', 'args': {'company': '谷歌公司'}, 'id': 'call_01_kS6NsF6YiYOYp6IvULAb1198', 'type': 'tool_call'}], invalid_tool_calls=[], usage_metadata={'input_tokens': 410, 'output_tokens': 112, 'total_tokens': 522, 'input_token_details': {'cache_read': 384}, 'output_token_details': {}}),

ToolMessage(content='谷歌公司 today价格: 15.42美元', name='get_stock_price', id='b454c4bf-984f-405f-831d-bb28bc040aea', tool_call_id='call_00_hQg6iYmwYKoPEL4zN1me4618'),

ToolMessage(content='谷歌发布新AI模型,性能提升20%\n谷歌与OpenAI合作,开发新的AI助手\n谷歌在欧洲展开AI研究项目', name='search_news', id='17200f34-b3fd-4dee-bb21-a36df39290f9', tool_call_id='call_01_kS6NsF6YiYOYp6IvULAb1198'), AIMessage(content='以下是谷歌公司(Alphabet Inc.)的最新信息汇总:\n\n---\n\n### 📊 股价信息\n- **当前股价**:**15.42 美元**(今日价格)\n\n---\n\n### 📰 最新新闻\n1. **谷歌发布新AI模型,性能提升20%** --- 谷歌推出了新一代AI模型,在性能上实现了20%的提升,进一步巩固其在人工智能领域的领先地位。\n\n2. **谷歌与OpenAI合作,开发新的AI助手** --- 谷歌与OpenAI强强联手,共同开发新的AI助手产品,这可能会给智能助手市场带来新的变数。\n\n3. **谷歌在欧洲展开AI研究项目** --- 谷歌持续扩大其全球AI布局,在欧洲启动了新的AI研究项目,推动技术创新。\n\n---\n\n从这些新闻可以看出,**人工智能(AI)**仍然是谷歌当前的核心战略方向,无论是在模型研发、产品合作还是全球研究布局上都在积极投入。', additional_kwargs={'refusal': None}, response_metadata={'token_usage': {'completion_tokens': 190, 'prompt_tokens': 578, 'total_tokens': 768, 'completion_tokens_details': None, 'prompt_tokens_details': {'audio_tokens': None, 'cached_tokens': 384}, 'prompt_cache_hit_tokens': 384, 'prompt_cache_miss_tokens': 194}, 'model_provider': 'deepseek', 'model_name': 'deepseek-v4-flash', 'system_fingerprint': 'fp_8b330d02d0_prod0820_fp8_kvcache_20260402', 'id': '35bb25cb-8f35-41c2-a8ef-65cef974c2c1', 'finish_reason': 'stop', 'logprobs': None}, id='lc_run--019e3030-8f78-7e73-956a-bfc7f0466cb7-0', tool_calls=[], invalid_tool_calls=[], usage_metadata={'input_tokens': 578, 'output_tokens': 190, 'total_tokens': 768, 'input_token_details': {'cache_read': 384}, 'output_token_details': {}})]}

相关推荐
2401_867623981 小时前
CSS Flex布局中如何设置子元素间距_掌握gap属性的现代用法
jvm·数据库·python
即使再小的船也能远航1 小时前
【Python】安装
开发语言·python
weixin_421725261 小时前
Linux 编程语言全解析:C、C++、Python、Go、Rust 谁更强?
linux·python·go·c·编程语言
没有梦想的咸鱼185-1037-16632 小时前
AI-Python机器学习、深度学习核心技术与前沿应用及OpenClaw、Hermes自动化编程
人工智能·python·深度学习·机器学习·chatgpt·数据挖掘·数据分析
axinawang2 小时前
第3课:变量与输入
python
idingzhi2 小时前
A股量化策略日报()
python
zyk_computer3 小时前
AI 时代,或许 Rust 比 Python 更合适
人工智能·后端·python·ai·rust·ai编程·vibe coding
weixin199701080163 小时前
【保姆级教程】淘宝/天猫商品详情 API(item_get)接入指南:Python/Java/PHP 调用示例与 JSON 返回值解析
java·python·php
萌新小码农‍3 小时前
python装饰器
开发语言·前端·python