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}"] # 追加一条日志
      }


相关推荐
齐 飞12 小时前
LangChain快速入门-03Retrieval(上)
langchain
怕浪猫13 小时前
第9章 实战项目一:智能数据分析Agent
langchain·aigc·ai编程
invicinble17 小时前
总结一下LangChain+LangGraph这套体系
langchain
糖果店的幽灵17 小时前
langchain 所有内置中间件最详细解析
中间件·langchain
阿拉斯攀登19 小时前
Agent 框架对比:LangChain / AutoGPT / CrewAI
人工智能·langchain·agent·rag·function
中微极客20 小时前
LangChain 0.3实战:企业级RAG与多Agent架构解析
人工智能·langchain·新人首发
喵叔哟1 天前
第一周概述
langchain·实战
RZhLyRaHv2 天前
LangChain教程-4、构建简易智能 PPT 生成器
人工智能·langchain·powerpoint
AI-好学者2 天前
RAG知识点_3_高级实践
人工智能·ai·架构·langchain·ai编程
大流星3 天前
LangChainJs之基础模型(一)
javascript·langchain