LLM结构化的概念讲解

1. 如何使用 Pydantic 定义结构化输出 Schema?(接口契约)

在没有结构化输出之前,让 LLM 写代码就像是对着对讲机喊话,对方回复的格式完全不可控。

你可以把Pydantic 定义的 Schema类比为微服务 RPC 通信中定义的 Protobuf ( .proto****文件) ,或者是 C++ 中的强类型结构体(Struct)。它明确规定了数据的"形状"。

思考逻辑:它是如何约束 Claude 的?

这并非简单的魔法,而是一个严密的转换流程:

  • 第一步(定义) :我们写下 class CoderOutputSchema(BaseModel),并用 Field 注释每个字段。
  • 第二步(翻译) :LangChain 底层的 **.with_structured_output()**会自动把这个 Python 类 ,翻译成标准的 JSON Schema
  • 第三步(调用) :LangChain 在向 Claude 发起 HTTP 请求时,会利用 Claude 的 Tool Calling(工具调用) 能力。它告诉 Claude:"你现在不是在聊天,你必须调用一个名为 CoderOutputSchema****的工具,并且必须填满 code****和 description****这两个参数。"
  • 第四步(解析):Claude 乖乖按要求返回了一段 JSON。LangChain 拿到后,又会自动用 Pydantic 把这段 JSON 反序列化成一个 Python 对象。

代码细节剖析:

复制代码
class CoderOutputSchema(BaseModel):
    # Field 的 description 非常关键!
    # 它不仅是给程序员看的注释,它会被作为 Prompt 的一部分直接喂给大模型。
    code: str = Field(description="生成的 Python 技能代码。必须是纯代码...")
    description: str = Field(description="对这段代码功能的简要描述。")
  • 防呆设计通过设定 code: str,如果 Claude 脑抽返回了一个数字或者列表,Pydantic 会在这一层直接抛出校验异常(ValidationError),而不会让这个脏数据流到下一个节点去引发崩溃。

2. 节点如何处理 LLM 的响应?(适配器模式)

在 LangGraph 中,节点(Node)本质上扮演着"适配器(Adapter)"的角色。

它像一个中间件,屏蔽了上下游的数据差异。它的左手边是 LangGraph 的全局 State,右手边是外部的 LLM。

思考逻辑:节点的数据流转过程

我们可以把 real_coder_node 的内部处理过程拆分为"拆解、调用、组装"三步:

  • 步骤一:拆解入参(从 State 提取上下文)
    • 节点接收到全局的字典 state
    • 它从中提取 LLM 需要的信息:user_req = state.get("user_requirement")。节点就像一个尽职的拦截器,只拿自己需要的数据,不管全局状态里还有什么其他乱七八糟的字段(比如之前的报错日志)。
  • 步骤二:执行调用(拿到结构化对象)
    • 调用 response = structured_llm.invoke(prompt)
    • 重点来了 :因为前面绑定了 Pydantic,这里的 response 已经不再是一段字符串文本了!它是一个实例化的 Python 对象。
    • 这就意味着,我们不需要写繁琐的代码去解析诸如 {"code": "...", "desc": "..."} 这样的字符串,而是可以直接通过点属性(点操作符)来访问数据:response.code。这就像在操作一个强类型的对象,极其安全和方便。
  • 步骤三:组装返回值(构建 State 补丁)
    • 节点不能把 response 这个对象直接丢给 LangGraph(因为 LangGraph 不认识它,只认识 State 中定义好的字段)。

    • 所以节点需要做一个"数据映射",把 LLM 的结果组装成图引擎要求的补丁包(Patch)

      return {
      "current_code": response.code, # 把对象里的代码提取出来,对齐到 State 的字段
      "execution_logs": [f"生成的技能: {response.description}"] # 追加一条日志
      }


相关推荐
老王熬夜敲代码2 小时前
AI小demo
langchain
咚咚2342 小时前
Langchain 调用 Agent Skills
langchain
java资料站3 小时前
第01章:LangChain使用概述
langchain
老王熬夜敲代码4 小时前
test_node流程详解
langchain
qq_54702617912 小时前
LangChain 中间件(Middleware)
中间件·langchain
Cha0DD12 小时前
【由浅入深探究langchain】第二十集-SQL Agent+Human-in-the-loop
人工智能·python·ai·langchain
Cha0DD12 小时前
【由浅入深探究langchain】第十九集-官方的SQL Agent示例
人工智能·python·ai·langchain
Barkamin21 小时前
LangChain简单介绍
langchain
百年੭ ᐕ)੭*⁾⁾1 天前
Chroma简单上手
人工智能·语言模型·langchain·chroma·rag