news 2026/6/10 19:04:16

智能体:天气助手实践

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
智能体:天气助手实践

Langchain 1.2.0 版本,实现天气查询

from dataclasses import dataclass from langchain.agents import create_agent from langchain.chat_models import init_chat_model from langchain.tools import tool, ToolRuntime from langgraph.checkpoint.memory import InMemorySaver import os from dotenv import load_dotenv load_dotenv() # 定义系统提示 SYSTEM_PROMPT = """你是一位擅长用双关语表达的专家天气预报员。 你可以使用两个工具: - get_weather_for_location:用于获取特定地点的天气 - get_user_location:用于获取用户的位置 如果用户询问天气,请确保你知道具体位置。如果从问题中可以判断他们指的是自己所在的位置,请使用 get_user_location 工具来查找他们的位置。""" # 定义上下文模式 @dataclass class Context: """自定义运行时上下文模式。""" user_id: str # 定义工具 @tool def get_weather_for_location(city: str) -> str: """获取指定城市的天气。""" return f"{city}总是阳光明媚!" @tool def get_user_location(runtime: ToolRuntime[Context]) -> str: """根据用户 ID 获取用户信息。""" user_id = runtime.context.user_id return "Florida" if user_id == "1" else "SF" # 配置模型 model = init_chat_model( #anthropic:claude-sonnet-4-5", #temperature=0 model = "deepseek-chat", base_url = "https://api.deepseek.com/v1", api_key = os.getenv("deepseek_api_key"), temperature = 0.7 ) # 定义响应格式 @dataclass class ResponseFormat: """代理的响应模式。""" # 带双关语的回应(始终必需) punny_response: str # 天气的任何有趣信息(如果有) weather_conditions: str | None = None # 设置记忆 checkpointer = InMemorySaver() # 创建代理 agent = create_agent( model=model, system_prompt=SYSTEM_PROMPT, tools=[get_user_location, get_weather_for_location], context_schema=Context, response_format=ResponseFormat, checkpointer=checkpointer ) # 运行代理 # `thread_id` 是给定对话的唯一标识符。 config = {"configurable": {"thread_id": "1"}} response = agent.invoke( {"messages": [{"role": "user", "content": "外面的天气怎么样?"}]}, config=config, context=Context(user_id="1") ) print(response['structured_response']) # ResponseFormat( # punny_response="佛罗里达今天依然是'阳光灿烂'的一天!阳光正在播放'rey-dio'热门歌曲!我得说,这是进行'solar-bration'的完美天气!如果你希望下雨,恐怕这个想法已经'被冲走'了——预报仍然'清晰地'灿烂!", # weather_conditions="佛罗里达总是阳光明媚!" # ) # 注意,我们可以使用相同的 `thread_id` 继续对话。 response = agent.invoke( {"messages": [{"role": "user", "content": "谢谢!"}]}, config=config, context=Context(user_id="1") ) print(response['structured_response']) # ResponseFormat( # punny_response="你真是'雷'厉风行地欢迎!帮助你保持'当前'天气总是'轻而易举'。我只是'云'游四方,等待随时'淋浴'你更多预报。祝你在佛罗里达的阳光下度过'sun-sational'的一天!", # weather_conditions=None # )

ResponseFormat(punny_response='佛罗里达的天气总是阳光明媚,就像这里的橙子一样"橙"意满满!看来太阳在这里"佛"常热情,让整个州都"罗"罩在温暖的光芒中。这里的天气真是"达"到了完美的度假标准!', weather_conditions='Florida总是阳光明媚!')
ResponseFormat(punny_response='不客气!很高兴能为您"预报"天气,希望我的回答让您"心晴"愉快!如果还有什么天气问题,我随时准备为您"云"开雾散!', weather_conditions=None)

Enjoy!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 9:46:35

九牧的韧性增长:从中国第一到世界第一

文 | 螳螂观察作者 | 余一在吴晓波2025年科技人文秀舞台上,“AI闪耀中国”的宏大叙事揭示了技术浪潮席卷一切的必然。从能文能武的机器人,到全面接管生活的AI大模型,再到被AI渗透与融合的先进制造业工厂,都在诠释真正的科技革命&a…

作者头像 李华
网站建设 2026/6/10 9:45:55

YOLOv8训练时imgsz640的作用是什么?分辨率影响解析

YOLOv8训练时imgsz640的作用解析:分辨率如何影响检测性能 在目标检测的实际项目中,我们常常会遇到这样一个问题:为什么几乎所有的YOLOv8教程和官方示例都默认使用 imgsz640?这个数字是随意选的吗?如果我用320、480甚至…

作者头像 李华
网站建设 2026/6/10 9:42:43

AI应用架构师总结:AI模型市场的“团队协作”流程设计

AI应用架构师总结:AI模型市场的“团队协作”流程设计 摘要/引言 在当今AI技术飞速发展的时代,AI模型市场蓬勃兴起。无论是开发新的AI模型以应用于各种场景,还是对现有模型进行优化与整合,团队协作都至关重要。然而,许多团队在协作过程中常常遭遇各种问题,比如沟通不畅导…

作者头像 李华
网站建设 2026/6/10 11:14:42

[特殊字符]_容器化部署的性能优化实战[20251231164650]

作为一名经历过多次容器化部署的工程师,我深知容器化环境下的性能优化有其独特之处。容器化虽然提供了良好的隔离性和可移植性,但也带来了新的性能挑战。今天我要分享的是在容器化环境下进行Web应用性能优化的实战经验。 💡 容器化环境的性能…

作者头像 李华
网站建设 2026/6/10 11:12:46

YOLOv8野生动物保护:盗猎行为视觉监测与报警

YOLOv8野生动物保护:盗猎行为视觉监测与报警 在非洲草原的深夜里,一只红外摄像头捕捉到远处有移动热源——是巡护员?还是持枪的盗猎者?传统监控系统可能要等几个小时才能被人发现这段录像,而那时,一头大象或…

作者头像 李华
网站建设 2026/6/10 9:14:44

一文说清jscope使用教程在嵌入式调试中的应用

如何用 jScope 看清嵌入式系统的“心跳”?——实战调试全解析 在电机嗡嗡作响、电源电压突降的瞬间,你是否曾对着串口打印的一长串数字发呆:“这到底是哪里出问题了?” 传统的 printf 调试像盲人摸象,只能感知局部…

作者头像 李华