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


相关推荐
code bean2 小时前
【LangChain】 入门:从分步调用到链式编程
langchain
C137的本贾尼5 小时前
从零认识 Spring AI:Java 开发者的 AI 第一课
python·langchain
Fleshy数模5 小时前
基于 LangChain 实现 PDF 文档检索:从加载到向量检索全流程
人工智能·数据挖掘·langchain·大模型
凌奕6 小时前
100 行代码搞懂多 Agent 协同:LangGraph 最小可运行示例(研究员 vs 批评家 + 总结员)
langchain·agent
janeysj7 小时前
OpenDeepResearch源码解析和二次开发
人工智能·langchain
爱跑步的程序员~8 小时前
RAG 技术全面解析:从原理到实践
python·ai·langchain·rag
Fleshy数模9 小时前
玩转 LangChain:从 Prompt 模板到多场景 AI 交互实战
人工智能·langchain·llm
夜影风10 小时前
LangGraph实战:搭建一个带人工介入的智能客服系统
人工智能·langchain·langgraph
网络工程小王11 小时前
【LangGraph 状态持久化(Checkpoint)详解】学习笔记
jvm·人工智能·笔记·langchain
chenyuhao202411 小时前
AI agent 开发之嵌入模型和提示词 前置知识
人工智能·深度学习·算法·langchain·agent·ai应用开发