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

电子商务如何设计网站建设微信机器人 wordpress 插件高级版

电子商务如何设计网站建设,微信机器人 wordpress 插件高级版,有多个网页的大网站如何做,wordpress如何导航网站模板这篇文章我们将 LangGraph中的控制流(边)和状态更新(节点)结合起来使用。比如,我们希望同时执行状态更新并决定下一步要转到哪个节点,且这些操作在同一个节点中完成。而正好 LangGraph 提供了一种方法&…

这篇文章我们将 LangGraph中的控制流(边)和状态更新(节点)结合起来使用。比如,我们希望同时执行状态更新并决定下一步要转到哪个节点,且这些操作在同一个节点中完成。而正好 LangGraph 提供了一种方法,可以通过从节点函数返回一个 Command 对象来实现这一点。

def my_node(state: State) -> Command[Literal["my_other_node"]]:return Command(# state updateupdate={"foo": "bar"},# control flowgoto="my_other_node")

如果我们使用的是 subgraphs(子图) 我们还可以通过 Command 中指定 graph=Command.PARENT这种方式,实现节点从一个子图导航到其他子图。

def my_node(state: State) -> Command[Literal["my_other_node"]]:return Command(update={"foo": "bar"},goto="other_subgraph",  # where `other_subgraph` is a node in the parent graphgraph=Command.PARENT)

当我们从子图节点向父图节点发送更新的时候,且更新的键同时存在于父图和子图的状态模式中时,我们必须为父图状态中正在更新的键定义一个 reducer。
下面我们开始我们的例子。

定义节点和State

定义 graph State:

class State(TypedDict):foo: str

定义节点A,

def node_a(state: State) -> Command[Literal["node_b", "node_c"]]:print("Called A")value = random.choice(["a", "b"])# 判断应该跳转到哪个节点if value == "a":goto = "node_b"else:goto = "node_c"# Command 允许我们同时更新图状态并路由到下一个节点。return Command(# 更新图中的状态update={"foo": value},# 替换edgegoto=goto,)

定义节点b或者c:

def node_b(state: State):print("Called B")return {"foo": state["foo"] + "b"}def node_c(state: State):print("Called C")return {"foo": state["foo"] + "c"}

定义好了上面节点之后,现在,我们可以使用上述节点创建 StateGraph。需要注意的是,该图没有定义条件的路由edge!这是因为控制流是用 Command 内部 node_a 定义的。

builder = StateGraph(State)
builder.add_edge(START, "node_a")
builder.add_node(node_a)
builder.add_node(node_b)
builder.add_node(node_c)graph = builder.compile()

不知道大家注意到没有,我们的 node_a 使用了 Command 作为返回类型注解,例如 Command[Literal[“node_b”, “node_c”]]。这一步对于图的渲染是非常必要的,它会告诉 LangGraph:node_a 可以导航到 node_b 和 node_c。
现在我们看看图的·1展示效果:

from IPython.display import display, Imagedisplay(Image(graph.get_graph().draw_mermaid_png()))

在这里插入图片描述
我们来试试多次调用graph:

graph.invoke({"foo": ""})

将会看到,graph会根据节点A中的随机选择,采用不同的路径(A-> B或A-> C)。

导航到 parent graph 中的节点

现在,让我们演示如何从 subgraph 内部导航到 parent graph 中的不同节点。我们将通过将上述示例中的 node_a 转换为一个单节点图来实现这一点,然后将其作为子图添加到 parent graph 中。

import operator
from typing_extensions import Annotatedclass State(TypedDict):# N定义一个reducer 自动附加消息foo: Annotated[str, operator.add]def node_a(state: State):print("Called A")value = random.choice(["a", "b"])if value == "a":goto = "node_b"else:goto = "node_c"# Command 允许我们同时更新图状态并路由到下一个节点。return Command(update={"foo": value},goto=goto,# 这会告诉 LangGraph 导航到父图中的 node_b 或 node_c 这将导航到相对于子图的最近的父图graph=Command.PARENT,)subgraph = StateGraph(State).add_node(node_a).add_edge(START, "node_a").compile()def node_b(state: State):print("Called B")# 由于我们已经定义了一个 reducer,因此不需要手动将新字符附加到现有的 foo 值上。相反,reducer 会自动(通过 operator.add)将这些值附加到现有值中。return {"foo": "b"}def node_c(state: State):print("Called C")return {"foo": "c"}

然后我们来构造graph:

builder = StateGraph(State)
builder.add_edge(START, "subgraph")
builder.add_node("subgraph", subgraph)
builder.add_node(node_b)
builder.add_node(node_c)graph = builder.compile()

查看效果:

Called A
Called C
{'foo': 'bc'}

到这里我们的代码就结束了,我们通过这种方式展示了如何使用 LangGraph 的 Command 对象在子图中更新状态并导航到父图中的不同节点。并通过 reducer 简化状态管理,就是自动保存消息链。

http://www.dtcms.com/wzjs/838856.html

相关文章:

  • 大连网站建设lccm中英互译网站怎么做
  • 做网站建设有前途那建设部网站 标准下载
  • 山东一建建设有限公司官方网站阿里巴巴国际贸易网站官网
  • 用spl做网站企业网站建设费用会计分录
  • 网站建设 顺德营销型网站建设ppt模板下载
  • 检测网站是否正常学做网站论坛VIP怎么样
  • 玉环县建设局网站怎样做网络推广在哪济南兴田德润什么活动
  • 域名注册网站建设温州网站建设最新报价
  • 做网页的网站叫什么软件kol营销
  • 传统企业网站建设环保设备东莞网站建设
  • 做出口的网站ghost系统怎么卸载wordpress
  • 网站seo诊断分析报告蜜芽加密通道入口2021
  • 变性人做网站嘉兴城乡建设厅网站
  • 织梦如何做响应式手机网站wordpress设置在新页面打开空白
  • 保险做的好的网站wordpress获取作者的文章
  • 梅州建站网络有限公司信阳市工程建设信息网站
  • 中国建设工程质量协会网站asp作业做购物网站代码
  • linux服务器安装网站网址大全123下载安装
  • 医院网站设计与实现网站建设中有关数据库问题
  • 网站登录页面空白网站建设读后感
  • 建设网站公司电话销售话术免费手机网站建站
  • 动易网站设计方案网站伪静态如何配置文件
  • 网站开发的三个流程寻找网站建设员
  • 怎样说服企业做网站建设推广专业seo培训学校
  • 手机自适应网站cpu游戏优化加速软件
  • 企业网站管理系统如何使用说明企业网站内容运营
  • WordPress网站hym地图关于旅行的网站怎样做
  • 做平面计设和网站哪个好与建设部网站
  • 接口网站建设ptp网站开发
  • 网站seo 教程企业网站管理系统软件