Documentation Index
Fetch the complete documentation index at: https://langchain-zh.cn/llms.txt
Use this file to discover all available pages before exploring further.
title: LangChain v1 迁移指南 sidebarTitle: LangChain v1
本指南概述了 LangChain v1 与之前版本之间的主要变更。简化的包
langchain 包命名空间在 v1 中已大幅缩减,专注于代理的核心构建块。精简后的包使得发现和核心功能的使用更加容易。
命名空间
| 模块 | 可用内容 | 备注 |
|---|---|---|
langchain.agents | create_agent, AgentState | 核心代理创建功能 |
langchain.messages | 消息类型,内容块, trim_messages | 从 langchain-core 重新导出 |
langchain.tools | @tool, BaseTool, 注入辅助工具 | 从 langchain-core 重新导出 |
langchain.chat_models | init_chat_model, BaseChatModel | 统一的模型初始化 |
langchain.embeddings | init_embeddings, Embeddings | 嵌入模型 |
langchain-classic
如果您之前使用了 langchain 包中的以下内容,则需要安装 langchain-classic 并更新您的导入语句:
- 旧版链式调用(
LLMChain,ConversationChain等) - 检索器(例如
MultiQueryRetriever或来自先前langchain.retrievers模块的任何内容) - 索引 API
- Hub 模块(用于编程管理提示词)
- 嵌入模块(例如
CacheBackedEmbeddings和社区嵌入) langchain-community重新导出- 其他已弃用的功能
迁移到 create_agent
在 v1.0 之前,我们推荐使用 langgraph.prebuilt.create_react_agent 来构建代理。现在,我们推荐使用 langchain.agents.create_agent 来构建代理。
下表概述了从 create_react_agent 到 create_agent 的功能变更:
| 部分 | 摘要 - 变更内容 |
|---|---|
| 导入路径 | 包从 langgraph.prebuilt 移至 langchain.agents |
| 提示词 | 参数重命名为 system_prompt,动态提示词使用中间件 |
| 模型前钩子 | 由带有 before_model 方法的中间件替换 |
| 模型后钩子 | 由带有 after_model 方法的中间件替换 |
| 自定义状态 | 仅支持 TypedDict,可通过 state_schema 或中间件定义 |
| 模型 | 通过中间件进行动态选择,不再支持预绑定模型 |
| 工具 | 工具错误处理移至带有 wrap_tool_call 的中间件 |
| 结构化输出 | 移除提示式输出,使用 ToolStrategy/ProviderStrategy |
| 流式节点名称 | 节点名称从 "agent" 更改为 "model" |
| 运行时上下文 | 依赖注入通过 context 参数而非 config["configurable"] |
| 命名空间 | 精简以专注于代理构建块,旧代码移至 langchain-classic |
导入路径
代理预置的导入路径已从langgraph.prebuilt 更改为 langchain.agents。
函数名称已从 create_react_agent 更改为 create_agent:
提示词
静态提示词重命名
prompt 参数已重命名为 system_prompt:
SystemMessage 到字符串
如果在系统提示中使用 SystemMessage 对象,请提取字符串内容:
动态提示词
动态提示词是核心上下文工程模式——它们根据当前对话状态调整您告诉模型的内容。为此,请使用@dynamic_prompt 装饰器:
模型前钩子
模型前钩子现在实现为带有before_model 方法的中间件。
这种新模式更具可扩展性——您可以定义多个中间件在调用模型之前运行,
在不同代理之间重用常见模式。
常见用例包括:
- 总结对话历史
- 修剪消息
- 输入护栏,如 PII 脱敏
模型后钩子
模型后钩子现在实现为带有after_model 方法的中间件。
这种新模式更具可扩展性——您可以定义多个中间件在调用模型之后运行,
在不同代理之间重用常见模式。
常见用例包括:
- 人机回环
- 输出护栏
自定义状态
自定义状态扩展了默认代理状态以包含额外字段。您可以通过两种方式定义自定义状态:- 通过
state_schema上的create_agent- 最适合在工具中使用的状态 - 通过中间件 - 最适合由特定中间件钩子和附加到该中间件的工具管理的状态
通过中间件定义自定义状态优于通过
state_schema 在 create_agent 上定义,因为它允许您将状态扩展概念性地限定在相关的中间件和工具范围内。state_schema 仍受支持以保持与 create_agent 的向后兼容性。通过 state_schema 定义状态
当您的自定义状态需要被工具访问时,请使用 state_schema 参数:
通过中间件定义状态
中间件也可以通过设置state_schema 属性来定义自定义状态。
这有助于将状态扩展概念性地限定在相关的中间件和工具范围内。
状态类型限制
create_agent 仅支持 TypedDict 作为状态架构。Pydantic 模型和数据类不再受支持。
langchain.agents.AgentState 而不是 BaseModel 或使用 dataclass 装饰即可。
如果您需要执行验证,请在中间件钩子中处理。
模型
动态模型选择允许您根据运行时上下文(例如任务复杂性、成本约束或用户偏好)选择不同的模型。create_react_agent 在 langgraph-prebuilt v0.6 中发布,支持通过传递给 model 参数的可调用对象进行动态模型和工具选择。
此功能已在 v1 中移植到中间件接口。
动态模型选择
预绑定模型
为了更好地支持结构化输出,create_agent 不再接受带有工具或配置的预绑定模型:
如果未使用结构化输出,动态模型函数可以返回预绑定模型。
工具
create_agent 的 tools 参数接受以下列表:
该参数将不再接受 ToolNode 实例。
处理工具错误
您现在可以使用实现wrap_tool_call 方法的中间件配置工具错误的处理方式。
结构化输出
节点变更
结构化输出过去是在主代理之外的单独节点中生成的。情况已不再如此。 我们在主循环中生成结构化输出,降低了成本和延迟。工具和提供者策略
在 v1 中,有两种新的结构化输出策略:ToolStrategy使用人工工具调用来生成结构化输出ProviderStrategy使用提供者原生的结构化输出生成
移除提示式输出
提示式输出不再通过response_format 参数支持。与人工工具调用和提供者原生结构化输出等策略相比,提示式输出已被证明不太可靠。
流式节点名称重命名
当从代理流式传输事件时,节点名称已从"agent" 更改为 "model",以更好地反映节点的用途。
运行时上下文
当您调用代理时,通常您需要传递两种类型的数据:- 在整个对话过程中变化的动态状态(例如,消息历史)
- 在对话期间不会变化的静态上下文(例如,用户元数据)
invoke 和 stream 的 context 参数来支持。
旧的
config["configurable"] 模式仍然适用于向后兼容,但建议新应用或迁移到 v1 的应用使用新的 context 参数。标准内容
在 v1 中,消息获得了与提供者无关的标准内容块。通过message.content_blocks 访问它们,以获得跨提供者的统一、类型化视图。现有的 message.content 字段保持不变,用于字符串或提供者原生结构。
变更内容
- 消息上新增
content_blocks属性用于标准化内容 - 标准化的块形状,记录在 消息 中
- 可选地将标准块序列化为
content,通过LC_OUTPUT_VERSION=v1或output_version="v1"
读取标准化内容
创建多模态消息
示例块形状
序列化标准内容
默认情况下,标准内容块不会序列化为content 属性。如果您需要在 content 属性中访问标准内容块(例如,当向客户端发送消息时),可以选择将它们序列化为 content。
简化的包
langchain 包命名空间在 v1 中已大幅缩减,专注于代理的核心构建块。精简后的包使得发现和核心功能的使用更加容易。
命名空间
| 模块 | 可用内容 | 备注 |
|---|---|---|
langchain.agents | create_agent, AgentState | 核心代理创建功能 |
langchain.messages | 消息类型,内容块, trim_messages | 从 langchain-core 重新导出 |
langchain.tools | @tool, BaseTool, 注入辅助工具 | 从 langchain-core 重新导出 |
langchain.chat_models | init_chat_model, BaseChatModel | 统一的模型初始化 |
langchain.embeddings | init_embeddings, Embeddings | 嵌入模型 |
langchain-classic
如果您之前使用了 langchain 包中的以下内容,则需要安装 langchain-classic 并更新您的导入语句:
- 旧版链式调用(
LLMChain,ConversationChain等) - 检索器(例如
MultiQueryRetriever或来自先前langchain.retrievers模块的任何内容) - 索引 API
- Hub 模块(用于编程管理提示词)
- 嵌入模块(例如
CacheBackedEmbeddings和社区嵌入) langchain-community重新导出- 其他已弃用的功能
重大变更
放弃对 Python 3.9 的支持
所有 LangChain 包现在都需要 Python 3.10 或更高版本。Python 3.9 将于 2025 年 10 月达到 生命周期结束。更新聊天模型的返回类型
聊天模型调用的返回类型签名已从BaseMessage 修复为 AIMessage。实现 bind_tools 的自定义聊天模型应更新其返回签名:
OpenAI Responses API 的默认消息格式
在与 Responses API 交互时,langchain-openai 现在默认将响应项存储在消息 content 中。要恢复以前的行为,请将 LC_OUTPUT_VERSION 环境变量设置为 v0,或在实例化 ChatOpenAI 时指定 output_version="v0"。
langchain-anthropic 中的默认 max_tokens
langchain-anthropic 中的 max_tokens 参数现在默认为基于所选模型的更高值,而不是之前的默认值 1024。如果您依赖于旧默认值,请显式设置 max_tokens=1024。
旧代码移至 langchain-classic
标准接口和代理重点之外的现有功能已移至 langchain-classic 包。有关核心 langchain 包中可用内容和移至 langchain-classic 的内容的详细信息,请参阅 简化命名空间 部分。
删除已弃用的 API
已经弃用并计划在 1.0 中删除的方法、函数和其他对象已被删除。请查看以前版本的 弃用通知 以获取替代 API。Text 属性
在消息对象上使用.text() 方法时应去掉括号,因为它现在是一个属性:
.text())将继续运行但现在会发出警告。方法形式将在 v2 中移除。
AIMessage 中移除了 example 参数
example 参数已从 AIMessage 对象中移除。我们建议使用 additional_kwargs 来传递所需的额外元数据。
次要变更
AIMessageChunk对象现在包含一个chunk_position属性,位置为'last',以指示流中的最后一个块。这使得流式消息的处理更加清晰。如果块不是最后一个,则chunk_position将为None。LanguageModelOutputVar现在类型为AIMessage而不是BaseMessage。- 合并消息块的逻辑(
AIMessageChunk.add)已更新,对合并块的最终 ID 进行了更复杂的处理。它优先使用提供者分配的 ID 而不是 LangChain 生成的 ID。 - 我们现在默认使用
utf-8编码打开文件。 - 标准测试现在使用多模态内容块。
归档文档
旧文档已归档供参考:Connect these docs to Claude, VSCode, and more via MCP for real-time answers.

