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

LangGraph-agent-天气助手

用于创建agent和多代理工作流 循环(有迭代次数)、可控、持久

安装langgraph包

conda create --name agent python=3.12
conda activate agent
pip install -U langgraph
pip install langchain-openai

设置

windows(>结尾)

setx OPENAI_BASE_URL "https://api.openai.com/v1"
setx OPENAI_API_KEY "sk-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"

api_key要去aihubmix上面去找自己的

linux(#结尾)

export OPENAI_BASE_URL="https://api.openai.com/v1"
export OPENAI_API_KEY="sk-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"

#示例:langgraph_hello.py
from typing import Literal
from langchain_core.messages import HumanMessage
from langchain_core.tools import tool
from langchain_openai import ChatOpenAI
# pip install langgraph
from langgraph.checkpoint.memory import MemorySaver
from langgraph.graph import END, StateGraph, MessagesState
from langgraph.prebuilt import ToolNode# 定义工具函数,用于代理调用外部工具
@tool
def search(query: str):"""模拟一个搜索工具"""if "上海" in query.lower() or "Shanghai" in query.lower():return "现在30度,有雾."return "现在是35度,阳光明媚。"# 将工具函数放入工具列表
tools = [search]# 创建工具节点
tool_node = ToolNode(tools)# 1.初始化模型和工具,定义并绑定工具到模型
model = ChatOpenAI(model="gpt-4o", temperature=0).bind_tools(tools)# 定义函数,决定是否继续执行
def should_continue(state: MessagesState) -> Literal["tools", END]:messages = state['messages']last_message = messages[-1]# 如果LLM调用了工具,则转到“tools”节点if last_message.tool_calls:return "tools"# 否则,停止(回复用户)return END# 定义调用模型的函数
def call_model(state: MessagesState):messages = state['messages']response = model.invoke(messages)# 返回列表,因为这将被添加到现有列表中return {"messages": [response]}# 2.用状态初始化图,定义一个新的状态图
workflow = StateGraph(MessagesState)
# 3.定义图节点,定义我们将循环的两个节点
workflow.add_node("agent", call_model)
workflow.add_node("tools", tool_node)# 4.定义入口点和图边
# 设置入口点为“agent”
# 这意味着这是第一个被调用的节点
workflow.set_entry_point("agent")# 添加条件边
workflow.add_conditional_edges(# 首先,定义起始节点。我们使用`agent`。# 这意味着这些边是在调用`agent`节点后采取的。"agent",# 接下来,传递决定下一个调用节点的函数。should_continue,
)# 添加从`tools`到`agent`的普通边。
# 这意味着在调用`tools`后,接下来调用`agent`节点。
workflow.add_edge("tools", 'agent')# 初始化内存以在图运行之间持久化状态
checkpointer = MemorySaver()# 5.编译图
# 这将其编译成一个LangChain可运行对象,
# 这意味着你可以像使用其他可运行对象一样使用它。
# 注意,我们(可选地)在编译图时传递内存
app = workflow.compile(checkpointer=checkpointer)# 6.执行图,使用可运行对象
final_state = app.invoke({"messages": [HumanMessage(content="上海的天气怎么样?")]},config={"configurable": {"thread_id": 42}}
)
# 从 final_state 中获取最后一条消息的内容
result = final_state["messages"][-1].content
print(result)
final_state = app.invoke({"messages": [HumanMessage(content="我问的那个城市?")]},config={"configurable": {"thread_id": 42}}
)
result = final_state["messages"][-1].content
print(result)

1.LangGraph核心组件:Graph(图)

步骤
1.初始化模型和工具  2.用状态初始化图 3.定义图节点 4.定义入口点和图边 5.编译图 6.执行图

agent为调用的大模型,虚线表示条件边

编译图 执行图

编译出现问题就是边没配置对  执行图就是langGhain的invoke调用

http://www.lryc.cn/news/2385220.html

相关文章:

  • 深度学习——超参数调优
  • 阿里云API RAG全流程实战:从模型调用到多模态应用的完整技术链路
  • 创建型:建造者模式
  • Jenkins集成Docker与K8S构建
  • redis缓存实战-19(使用 Pub/Sub 构建简单的聊天应用程序)
  • UE4游戏查找本地角色数据的方法-SDK
  • 游园安排--最长上升子序列+输出序列
  • 缓存一致性与AI内容生成的幂等控制
  • Java 连接并操作 Redis 万字详解:从 Jedis 直连到 RedisTemplate 封装,5 种方式全解析
  • python web 开发-Flask-Login使用详解
  • 快速排序算法的C++和C语言对比
  • 分布式事务知识点整理
  • 微信小程序数据接收
  • 鸿蒙UI开发——badge角标的使用
  • 批量打印的趣事
  • 车载中央域控制器测试【BCM模块介绍-外灯3】
  • Linux系统基础——是什么、适用在哪里、如何选
  • MySQL与Oracle六大方面之比较
  • 二层和三层交换机的概念
  • 计算机网络学习20250524
  • 无损图片压缩 本地处理 批量处理提升效率 无需联网+无广告
  • C++标准库中 std::string 类提供的 insert 成员函数的不同重载版本
  • Qt window frame + windowTitle + windowIcon属性(3)
  • 解决:VMware 虚拟机 Ubuntu 系统共享文件夹无法访问问题
  • Dify源码学习
  • 静态网站部署:如何通过GitHub免费部署一个静态网站
  • 【拯救小狗】2022-1-3
  • PS2025 v26.7 Photoshop2025+AI生图扩充版,支持AI画图
  • 怎么开发一个网络协议模块(C语言框架)之(三) 全局实例
  • ShenNiusModularity项目源码学习(30:ShenNius.Admin.Mvc项目分析-15)