Documentation Index Fetch the complete documentation index at: https://nvd-54.mintlify.app/llms.txt
Use this file to discover all available pages before exploring further.
create_deep_agent 有以下核心配置选项:
create_deep_agent (
model : str | BaseChatModel | None = None ,
tools : Sequence [ BaseTool | Callable | dict [ str , Any ]] | None = None ,
* ,
system_prompt : str | SystemMessage | None = None ,
middleware : Sequence [ AgentMiddleware ] = (),
subagents : Sequence [ SubAgent | CompiledSubAgent | AsyncSubAgent ] | None = None ,
skills : list [ str ] | None = None ,
memory : list [ str ] | None = None ,
permissions : list [ FilesystemPermission ] | None = None ,
backend : BackendProtocol | BackendFactory | None = None ,
interrupt_on : dict [ str , bool | InterruptOnConfig ] | None = None ,
response_format : ResponseFormat [ ResponseT ] | type [ ResponseT ] | dict [ str , Any ] | None = None ,
context_schema : type [ ContextT ] | None = None ,
checkpointer : Checkpointer | None = None ,
store : BaseStore | None = None ,
debug : bool = False ,
name : str | None = None ,
cache : BaseCache | None = None
) -> CompiledStateGraph [ AgentState [ ResponseT ], ContextT , _InputAgentState , _OutputAgentState [ ResponseT ]]
完整参数列表请参阅 create_deep_agent API 参考。
传入 provider:model 格式的 model 字符串,或已初始化的模型实例。查看支持的模型 了解所有提供商,查看推荐模型 了解经过测试的推荐方案。
使用 provider:model 格式(例如 openai:gpt-5.4)可快速在模型之间切换。
OpenAI
Anthropic
Azure
Google Gemini
AWS Bedrock
HuggingFace
Other
👉 Read the OpenAI chat model integration docs pip install -U "langchain[openai]"
default parameters
init_chat_model
Model Class
import os
from deepagents import create_deep_agent
os . environ [ " OPENAI_API_KEY " ] = "sk-..."
agent = create_deep_agent ( model = "openai:gpt-5.4" )
# this calls init_chat_model for the specified model with default parameters
# to use specific model parameters, use init_chat_model directly
👉 Read the Anthropic chat model integration docs pip install -U "langchain[anthropic]"
default parameters
init_chat_model
Model Class
import os
from deepagents import create_deep_agent
os . environ [ " ANTHROPIC_API_KEY " ] = "sk-..."
agent = create_deep_agent ( model = "anthropic:claude-sonnet-4-6" )
# this calls init_chat_model for the specified model with default parameters
# to use specific model parameters, use init_chat_model directly
👉 Read the Azure chat model integration docs pip install -U "langchain[openai]"
default parameters
init_chat_model
Model Class
import os
from deepagents import create_deep_agent
os . environ [ " AZURE_OPENAI_API_KEY " ] = "..."
os . environ [ " AZURE_OPENAI_ENDPOINT " ] = "..."
os . environ [ " OPENAI_API_VERSION " ] = "2025-03-01-preview"
agent = create_deep_agent ( model = "azure_openai:gpt-5.4" )
# this calls init_chat_model for the specified model with default parameters
# to use specific model parameters, use init_chat_model directly
👉 Read the Google GenAI chat model integration docs pip install -U "langchain[google-genai]"
default parameters
init_chat_model
Model Class
import os
from deepagents import create_deep_agent
os . environ [ " GOOGLE_API_KEY " ] = "..."
agent = create_deep_agent ( model = "google_genai:gemini-3.1-pro-preview" )
# this calls init_chat_model for the specified model with default parameters
# to use specific model parameters, use init_chat_model directly
👉 Read the AWS Bedrock chat model integration docs pip install -U "langchain[aws]"
default parameters
init_chat_model
Model Class
from deepagents import create_deep_agent
# Follow the steps here to configure your credentials:
# https://docs.aws.amazon.com/bedrock/latest/userguide/getting-started.html
agent = create_deep_agent (
model = "anthropic.claude-sonnet-4-6" ,
model_provider = "bedrock_converse" ,
)
# this calls init_chat_model for the specified model with default parameters
# to use specific model parameters, use init_chat_model directly
👉 Read the HuggingFace chat model integration docs pip install -U "langchain[huggingface]"
default parameters
init_chat_model
Model Class
import os
from deepagents import create_deep_agent
os . environ [ " HUGGINGFACEHUB_API_TOKEN " ] = "hf_..."
agent = create_deep_agent (
model = "microsoft/Phi-3-mini-4k-instruct" ,
model_provider = "huggingface" ,
temperature = 0.7 ,
max_tokens = 1024 ,
)
# this calls init_chat_model for the specified model with default parameters
# to use specific model parameters, use init_chat_model directly
Pass any supported model string , or an initialized model instance: model string
init_chat_model
model class
from deepagents import create_deep_agent
agent = create_deep_agent ( model = "provider:model-name" )
Chat Model 会自动重试临时 API 故障(使用指数退避)。有关默认值、限制以及调整 max_retries / timeout 的代码示例,请参阅 LangChain 模型 页面。
除了用于规划、文件管理和子 Agent 派生的内置工具 外,你还可以提供自定义工具:
Google
OpenAI
Anthropic
OpenRouter
Fireworks
Baseten
Ollama
import os
from typing import Literal
from tavily import TavilyClient
from deepagents import create_deep_agent
tavily_client = TavilyClient ( api_key = os . environ [ " TAVILY_API_KEY " ])
def internet_search (
query : str ,
max_results : int = 5 ,
topic : Literal [ " general " , " news " , " finance " ] = "general" ,
include_raw_content : bool = False ,
):
"""Run a web search"""
return tavily_client . search (
query ,
max_results = max_results ,
include_raw_content = include_raw_content ,
topic = topic ,
)
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
tools = [ internet_search ],
)
系统提示词
Deep Agents 内置了系统提示词。Deep Agent 的价值来自 SDK 在模型之上提供的编排层——规划、虚拟文件系统工具和子 Agent——模型需要知道这些工具的存在以及何时使用它们。内置提示词教会 Agent 如何使用这些脚手架,因此你不需要在每个项目中重新推导;通过配置文件 或你自己的 system_prompt= 来调整,而不是逐字复制。
当 Middleware 添加特殊工具(如文件系统工具)时,它会将工具追加到系统提示词中。
每个 Deep Agent 还应包含针对其特定用例的自定义系统提示词:
Google
OpenAI
Anthropic
OpenRouter
Fireworks
Baseten
Ollama
from deepagents import create_deep_agent
research_instructions = """ \
You are an expert researcher. Your job is to conduct \
thorough research, and then write a polished report. \
"""
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
system_prompt = research_instructions ,
)
提示词组装
Deep Agents 从最多四个命名部分构建系统提示词,使得调用方提供的指令、SDK 内置的 Agent 指导和任何模型特定的配置文件 覆盖可以以可预测的优先级共存。如果没有这种分层,针对 Claude 调优的配置后缀(例如)可能会根据调用顺序覆盖或被你的 system_prompt= 参数覆盖;命名槽使排序显式且稳定。
在实践中,大多数调用方只会遇到两个槽:USER(你的 system_prompt=)和 BASE(SDK 默认值)。选择带有内置配置的模型(目前是 Anthropic 或 OpenAI)会添加一个 SUFFIX。完整的四部分组装主要与你编写自定义 HarnessProfile 或调试配置文本出现位置时相关。
四个命名部分(每个可能不存在):
名称 来源 说明 USERcreate_deep_agent 的 system_prompt= 参数str 或 SystemMessage;未设置时省略。BASESDK 默认值(BASE_AGENT_PROMPT) 始终存在,除非被配置的 CUSTOM 替换。 CUSTOMHarnessProfile.base_system_prompt当匹配的配置设置时,直接替换 BASE。 SUFFIXHarnessProfile.system_prompt_suffix当匹配的配置设置时,追加到最后。
顺序始终为 USER -> (BASE 或 CUSTOM) -> SUFFIX ,用空行(\n\n)连接。由此得出两个不变量:
USER 始终在最前面。 调用方的文本先于任何 SDK 或配置内容,因此无论选择哪个模型,角色/指令都具有最高优先级。
SUFFIX 始终在最后。 配置后缀最靠近对话历史,这是模型调优指导最可靠落地的位置。
组装形态(✓ = 已设置字段,- = 未设置字段):
system_prompt=配置 base_system_prompt(CUSTOM) 配置 system_prompt_suffix(SUFFIX) 最终组装的系统提示词 None- - BASENone- ✓ BASE + SUFFIXNone✓ - CUSTOMNone✓ ✓ CUSTOM + SUFFIXstr- - USER + BASEstr- ✓ USER + BASE + SUFFIXstr✓ - USER + CUSTOMstr✓ ✓ USER + CUSTOM + SUFFIX
实例——内置配置(Anthropic、OpenAI)仅提供 system_prompt_suffix,因此典型调用落在 str + - + ✓ 行:
agent = create_deep_agent (
model = "anthropic:claude-sonnet-4-6" ,
system_prompt = "You are a customer-support agent for ACME Corp." ,
)
# 最终 = USER + BASE + SUFFIX
# = "You are a customer-support agent for ACME Corp."
# + "\n\n"
# + BASE_AGENT_PROMPT
# + "\n\n"
# + <Claude 特定指导>
传递 SystemMessage(而不是字符串)会触发不同的拼接路径:右侧组装(BASE 或 CUSTOM 加上任何 SUFFIX)作为额外的文本内容块追加到消息的现有 content_blocks 上。相同的逻辑排序适用(调用方的块在前),调用方块上的任何 cache_control 标记会被保留——这对于放置显式的 Anthropic Prompt 缓存断点很有用。
相同的覆盖规则适用于声明式子 Agent ——每个子 Agent 针对自己的模型 重新运行配置解析,然后将解析后的配置的 base_system_prompt / system_prompt_suffix 应用于其编写的 system_prompt。子 Agent 的 system_prompt 扮演 BASE 角色;CUSTOM 和 SUFFIX 来自匹配子 Agent 模型的配置(可能与主 Agent 的配置不同)。 spec["system_prompt"]配置 base_system_prompt(CUSTOM) 配置 system_prompt_suffix(SUFFIX) 最终子 Agent 系统提示词 已编写 - - 已编写 已编写 - ✓ 已编写 + SUFFIX 已编写 ✓ - CUSTOM已编写 ✓ ✓ CUSTOM + SUFFIX
子 Agent 没有 USER 段——规格中编写的 system_prompt 是最接近的类比,保留在 BASE 槽中。仅提供 system_prompt_suffix 的配置(内置 Anthropic / OpenAI 配置的常见情况)只是追加到子 Agent 作者编写的内容之后;设置 base_system_prompt 的配置会直接替换 编写的提示词,因此请谨慎使用该字段。
自动添加的通用子 Agent 遵循相同的覆盖规则,但多了一层:GP 基础提示词的解析顺序为 general_purpose_subagent.system_prompt(如果设置)-> HarnessProfile.base_system_prompt(如果设置)-> SDK GP 默认值 。配置后缀无论如何都会叠加在上面。 这两个覆盖字段都可以承载基础提示词替换,但它们不可互换。general_purpose_subagent.system_prompt 是 GP 特定的配置;base_system_prompt 是主要针对主 Agent 的全局覆盖。当两者都设置时,GP 特定的意图对 GP 子 Agent 优先生效 ,这样同时调整两个字段的用户不会看到其 GP 覆盖被静默丢弃: register_harness_profile (
"anthropic" ,
HarnessProfile (
base_system_prompt = "You are ACME's support orchestrator." , # 主 Agent
general_purpose_subagent = GeneralPurposeSubagentProfile (
system_prompt = "You are a research subagent. Cite sources." , # GP 子 Agent
),
system_prompt_suffix = "Always think step by step." ,
),
)
栈 最终系统提示词 主 Agent "You are ACME's support orchestrator." + SUFFIXGP 子 Agent "You are a research subagent. Cite sources." + SUFFIX
如果 general_purpose_subagent.system_prompt 未设置,GP 子 Agent 回退到 base_system_prompt(如果设置),最终回退到 SDK GP 默认值。
Middleware
Deep Agents 支持任何 Middleware ,包括下面列出的内置 Middleware、LangChain 的预构建 Middleware、特定提供商的 Middleware,以及你自己编写的自定义 Middleware。将 Middleware 传递给 create_deep_agent 的 middleware 参数。
默认情况下,Deep Agents 可以使用以下 Middleware:
如果你使用记忆、技能或人机协作,还会包含以下 Middleware:
预构建 Middleware
LangChain 提供额外的预构建 Middleware,让你可以添加各种功能,如重试、回退或 PII 检测。参见预构建 Middleware 了解更多。
deepagents 库还暴露了 create_summarization_tool_middleware ,使 Agent 能够在适当的时机触发摘要——例如在任务之间——而不是在固定的 Token 间隔。更多详情请参阅摘要 。
特定提供商 Middleware
有关针对特定 LLM 提供商优化的 Middleware,请参阅官方集成 和社区集成 。
自定义 Middleware
你可以提供额外的 Middleware 来扩展功能、添加工具或实现自定义钩子:
Google
OpenAI
Anthropic
OpenRouter
Fireworks
Baseten
Ollama
from langchain . agents . middleware import wrap_tool_call
from langchain . tools import tool
from deepagents import create_deep_agent
@tool
def get_weather ( city : str ) -> str :
"""Get the weather in a city."""
return f "The weather in { city } is sunny."
call_count = [ 0 ] # 使用列表以便在嵌套函数中修改
@wrap_tool_call
def log_tool_calls ( request , handler ):
"""拦截并记录每次 Tool 调用 - 演示横切关注点。"""
call_count [ 0 ] += 1
tool_name = request . name if hasattr ( request , "name" ) else str ( request )
print ( f "[Middleware] Tool 调用 # { call_count [ 0 ] } : { tool_name } " )
print ( f "[Middleware] 参数: { request . args if hasattr ( request , 'args' ) else 'N/A' } " )
# 执行 Tool 调用
result = handler ( request )
# 记录结果
print ( f "[Middleware] Tool 调用 # { call_count [ 0 ] } 完成" )
return result
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
tools = [ get_weather ],
middleware = [ log_tool_calls ],
)
不要在初始化后修改属性 如果你需要在钩子调用之间跟踪值(例如计数器或累积数据),请使用 Graph State。
Graph State 在设计上限定于线程作用域,因此在并发下更新是安全的。 应该这样做: from langchain . agents . middleware import AgentMiddleware
class CustomMiddleware ( AgentMiddleware ):
def __init__ ( self ):
pass
def before_agent ( self , state , runtime ):
return { "x" : state . get ( "x" , 0 ) + 1 } # 改为更新 Graph State
不要 这样做:class CustomMiddlewareBad ( AgentMiddleware ):
def __init__ ( self ):
self . x = 1
def before_agent ( self , state , runtime ):
self . x += 1 # 直接修改实例属性会导致竞态条件
就地变更,如在 before_agent 中修改 self.x 或在钩子中更改其他共享值,可能导致微妙的 bug 和竞态条件,因为许多操作是并发运行的(子 Agent、并行工具和不同线程上的并行调用)。 有关使用自定义属性扩展状态的完整详情,请参阅自定义 Middleware - 自定义状态 Schema 。
如果你必须在自定义 Middleware 中使用变更,请考虑当子 Agent、并行工具或并发 Agent 调用同时运行时会发生什么。
解释器
使用解释器 添加一个 eval 工具,在限定范围的 QuickJS 运行时中运行 JavaScript。当 Agent 需要以编程方式组合工具、批量处理工作、在代码中处理错误或转换结构化数据而不需要完整的 Shell 环境时,解释器非常有用。
Google
OpenAI
Anthropic
OpenRouter
Fireworks
Baseten
Ollama
from deepagents import create_deep_agent
from langchain_quickjs import CodeInterpreterMiddleware
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
middleware = [ CodeInterpreterMiddleware ()],
)
有关设置、程序化工具调用、解释器技能和限制,请参阅解释器 。
子 Agent
要隔离详细工作并避免上下文膨胀,请使用子 Agent:
import os
from typing import Literal
from tavily import TavilyClient
from deepagents import create_deep_agent
tavily_client = TavilyClient ( api_key = os . environ [ " TAVILY_API_KEY " ])
def internet_search (
query : str ,
max_results : int = 5 ,
topic : Literal [ " general " , " news " , " finance " ] = "general" ,
include_raw_content : bool = False ,
):
"""Run a web search"""
return tavily_client . search (
query ,
max_results = max_results ,
include_raw_content = include_raw_content ,
topic = topic ,
)
research_subagent = {
"name" : "research-agent" ,
"description" : "Used to research more in depth questions" ,
"system_prompt" : "You are a great researcher" ,
"tools" : [ internet_search ],
"model" : "openai:gpt-5.4" , # Optional override, defaults to main agent model
}
subagents = [ research_subagent ]
agent = create_deep_agent (
model = "claude-sonnet-4-6" ,
subagents = subagents
)
更多信息请参阅子 Agent 。
Deep Agent 的工具可以使用虚拟文件系统来存储、访问和编辑文件。默认情况下,Deep Agents 使用 StateBackend 。
如果你使用技能 或记忆 ,你必须在创建 Agent 之前将预期的技能或记忆文件添加到后端。
StateBackend
FilesystemBackend
LocalShellBackend
StoreBackend
ContextHubBackend
CompositeBackend
线程作用域的文件系统后端,存储在 langgraph State 中。 文件在同一线程内跨轮次持久化(通过 Checkpointer),不会跨线程共享。 # 默认情况下 we provide a StateBackend
agent = create_deep_agent ( model = "google_genai:gemini-3.1-pro-preview" )
# Under the hood, it looks like
from deepagents . backends import StateBackend
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
backend = StateBackend ()
)
本地机器的文件系统。 from deepagents . backends import FilesystemBackend
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
backend = FilesystemBackend ( root_dir = "." , virtual_mode = True )
)
直接在主机上执行的文件系统和 Shell。提供文件系统工具和用于运行命令的 execute 工具。 此后端授予 Agent 直接的文件系统读写访问权限以及 在主机上不受限的 Shell 执行。
请极其谨慎使用,仅在适当的环境中使用。
更多信息请参阅 LocalShellBackend 。 from deepagents . backends import LocalShellBackend
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
backend = LocalShellBackend ( root_dir = "." , env = { "PATH" : "/usr/bin:/bin" })
)
提供_跨线程持久化_的长期存储文件系统。 from langgraph . store . memory import InMemoryStore
from deepagents . backends import StoreBackend
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
backend = StoreBackend (
namespace = lambda ctx : ( ctx . runtime . context . user_id ,),
),
store = InMemoryStore () # Good for local dev; omit for LangSmith Deployment
)
When deploying to LangSmith Deployment , omit the store parameter. The platform automatically provisions a store for your agent. namespace 参数控制数据隔离。对于多用户部署,始终设置命名空间工厂 以按用户或租户隔离数据。LangSmith Hub 仓库中的持久化文件系统存储。 from deepagents . backends import ContextHubBackend
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
backend = ContextHubBackend ( "my-agent" )
)
更多详情请参阅 ContextHubBackend 。 灵活的后端,你可以指定文件系统中的不同路由指向不同后端。 from deepagents import create_deep_agent
from deepagents . backends import CompositeBackend , StateBackend , StoreBackend
from langgraph . store . memory import InMemoryStore
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
backend = CompositeBackend (
default = StateBackend (),
routes = {
"/memories/" : StoreBackend (),
}
),
store = InMemoryStore () # Store passed to create_deep_agent, not backend
)
更多信息请参阅后端 。
Sandbox
Sandbox 是专门的后端 ,在隔离环境中运行 Agent 代码,拥有自己的文件系统和用于 Shell 命令的 execute 工具。
当你希望 Deep Agent 写文件、安装依赖和运行命令而不影响本地机器时,使用 Sandbox 后端。
通过在创建 Deep Agent 时将 Sandbox 后端传递给 backend 来配置 Sandbox:
Modal
Runloop
Daytona
LangSmith
pip install langchain-modal
import modal
from deepagents import create_deep_agent
from langchain_anthropic import ChatAnthropic
from langchain_modal import ModalSandbox
app = modal . App . lookup ( "your-app" )
modal_sandbox = modal . Sandbox . create ( app = app )
backend = ModalSandbox ( sandbox = modal_sandbox )
agent = create_deep_agent (
model = ChatAnthropic ( model = "claude-sonnet-4-6" ),
system_prompt = "You are a Python coding assistant with sandbox access." ,
backend = backend ,
)
try :
result = agent . invoke (
{
"messages" : [
{
"role" : "user" ,
"content" : "Create a small Python package and run pytest" ,
}
]
}
)
finally :
modal_sandbox . terminate ()
pip install langchain-runloop
import os
from deepagents import create_deep_agent
from langchain_anthropic import ChatAnthropic
from langchain_runloop import RunloopSandbox
from runloop_api_client import RunloopSDK
client = RunloopSDK ( bearer_token = os . environ [ " RUNLOOP_API_KEY " ])
devbox = client . devbox . create ()
backend = RunloopSandbox ( devbox = devbox )
agent = create_deep_agent (
model = ChatAnthropic ( model = "claude-sonnet-4-6" ),
system_prompt = "You are a Python coding assistant with sandbox access." ,
backend = backend ,
)
try :
result = agent . invoke (
{
"messages" : [
{
"role" : "user" ,
"content" : "Create a small Python package and run pytest" ,
}
]
}
)
finally :
devbox . shutdown ()
pip install langchain-daytona
from daytona import Daytona
from deepagents import create_deep_agent
from langchain_anthropic import ChatAnthropic
from langchain_daytona import DaytonaSandbox
sandbox = Daytona (). create ()
backend = DaytonaSandbox ( sandbox = sandbox )
agent = create_deep_agent (
model = ChatAnthropic ( model = "claude-sonnet-4-6" ),
system_prompt = "You are a Python coding assistant with sandbox access." ,
backend = backend ,
)
try :
result = agent . invoke (
{
"messages" : [
{
"role" : "user" ,
"content" : "Create a small Python package and run pytest" ,
}
]
}
)
finally :
sandbox . stop ()
LangSmith sandboxes are currently in private beta.
pip install "langsmith[sandbox]"
from deepagents import create_deep_agent
from deepagents . backends import LangSmithSandbox
from langchain_anthropic import ChatAnthropic
from langsmith . sandbox import SandboxClient
client = SandboxClient ()
ls_sandbox = client . create_sandbox ( template_name = "my-template" )
backend = LangSmithSandbox ( sandbox = ls_sandbox )
agent = create_deep_agent (
model = ChatAnthropic ( model = "claude-sonnet-4-6" ),
system_prompt = "You are a Python coding assistant with sandbox access." ,
backend = backend ,
)
try :
result = agent . invoke (
{
"messages" : [
{
"role" : "user" ,
"content" : "Create a small Python package and run pytest" ,
}
]
}
)
finally :
client . delete_sandbox ( ls_sandbox . name )
更多信息请参阅 Sandbox 。
人机协作
某些工具操作可能是敏感的,需要在执行前获得人工批准。
你可以为每个工具配置审批流程:
from langchain . tools import tool
from deepagents import create_deep_agent
from langgraph . checkpoint . memory import MemorySaver
@tool
def delete_file ( path : str ) -> str :
"""Delete a file from the filesystem."""
return f "Deleted { path } "
@tool
def read_file ( path : str ) -> str :
"""Read a file from the filesystem."""
return f "Contents of { path } "
@tool
def send_email ( to : str , subject : str , body : str ) -> str :
"""Send an email."""
return f "Sent email to { to } "
# Checkpointer is REQUIRED for human-in-the-loop
checkpointer = MemorySaver ()
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
tools = [ delete_file , read_file , send_email ],
interrupt_on = {
"delete_file" : True , # Default: approve, edit, reject, respond
"read_file" : False , # No interrupts needed
"send_email" : { "allowed_decisions" : [ "approve" , "reject" ]}, # No editing
},
checkpointer = checkpointer # Required!
)
你可以在工具调用时以及工具调用内部为 Agent 和子 Agent 配置 Interrupt。
更多信息请参阅人机协作 。
你可以使用技能 为 Deep Agent 提供新的能力和专业知识。
虽然工具 倾向于覆盖较低级别的功能,如原生文件系统操作或规划,技能可以包含关于如何完成任务的详细说明、参考信息和其他资产(如模板)。
这些文件仅在 Agent 确定该技能对当前 Prompt 有用时才由 Agent 加载。
这种渐进式披露减少了 Agent 在启动时需要考虑的 Token 和上下文量。
有关示例技能,请参阅 Deep Agents 示例技能 。
要将技能添加到 Deep Agent,将它们作为参数传递给 create_deep_agent:
StateBackend
StoreBackend
FilesystemBackend
from urllib . request import urlopen
from deepagents import create_deep_agent
from deepagents . backends . utils import create_file_data
from langgraph . checkpoint . memory import MemorySaver
from deepagents . backends import StateBackend
from langchain_quickjs import CodeInterpreterMiddleware
checkpointer = MemorySaver ()
backend = StateBackend ()
skill_url = "https://raw.githubusercontent.com/langchain-ai/deepagents/refs/heads/main/libs/cli/examples/skills/langgraph-docs/SKILL.md"
with urlopen ( skill_url ) as response :
skill_content = response . read (). decode ( 'utf-8' )
skills_files = {
"/skills/langgraph-docs/SKILL.md" : create_file_data ( skill_content )
}
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
backend = backend ,
skills = [ "/skills/" ],
checkpointer = checkpointer ,
middleware = [ CodeInterpreterMiddleware ( skills_backend = backend )] # for interpreter skills
)
result = agent . invoke (
{
"messages" : [
{
"role" : "user" ,
"content" : "What is langgraph?" ,
}
],
# Seed the default StateBackend's in-state filesystem (virtual paths must start with "/").
"files" : skills_files
},
config = { "configurable" : { "thread_id" : "12345" }},
)
from urllib . request import urlopen
from deepagents import create_deep_agent
from deepagents . backends import StoreBackend
from deepagents . backends . utils import create_file_data
from langgraph . store . memory import InMemoryStore
from langchain_quickjs import CodeInterpreterMiddleware
store = InMemoryStore ()
backend = StoreBackend ()
skill_url = "https://raw.githubusercontent.com/langchain-ai/deepagents/refs/heads/main/libs/cli/examples/skills/langgraph-docs/SKILL.md"
with urlopen ( skill_url ) as response :
skill_content = response . read (). decode ( 'utf-8' )
store . put (
namespace = ( "filesystem" ,),
key = "/skills/langgraph-docs/SKILL.md" ,
value = create_file_data ( skill_content )
)
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
backend = backend ,
store = store ,
skills = [ "/skills/" ],
middleware = [ CodeInterpreterMiddleware ( skills_backend = backend )] # for interpreter skills
)
result = agent . invoke (
{
"messages" : [
{
"role" : "user" ,
"content" : "What is langgraph?" ,
}
]
},
config = { "configurable" : { "thread_id" : "12345" }},
)
from deepagents import create_deep_agent
from langgraph . checkpoint . memory import MemorySaver
from deepagents . backends . filesystem import FilesystemBackend
from langchain_quickjs import CodeInterpreterMiddleware
# Checkpointer is REQUIRED for human-in-the-loop
checkpointer = MemorySaver ()
backend = FilesystemBackend ( root_dir = "/Users/user/ {project} " )
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
backend = ,
skills = [ "/Users/user/ {project} /skills/" ],
interrupt_on = {
"write_file" : True , # Default: approve, edit, reject
"read_file" : False , # No interrupts needed
"edit_file" : True # Default: approve, edit, reject
},
checkpointer = checkpointer , # Required!
middleware = [ CodeInterpreterMiddleware ( skills_backend = backend )] # for interpreter skills
)
result = agent . invoke (
{
"messages" : [
{
"role" : "user" ,
"content" : "What is langgraph?" ,
}
]
},
config = { "configurable" : { "thread_id" : "12345" }},
)
使用 AGENTS.md 文件 为 Deep Agent 提供额外上下文。
创建 Deep Agent 时,你可以将一个或多个文件路径传递给 memory 参数:
StateBackend
StoreBackend
FilesystemBackend
Google
OpenAI
Anthropic
OpenRouter
Fireworks
Baseten
Ollama
from urllib . request import urlopen
from deepagents import create_deep_agent
from deepagents . backends . utils import create_file_data
from langgraph . checkpoint . memory import MemorySaver
with urlopen (
"https://raw.githubusercontent.com/langchain-ai/deepagents/refs/heads/main/examples/text-to-sql-agent/AGENTS.md"
) as response :
agents_md = response . read (). decode ( "utf-8" )
checkpointer = MemorySaver ()
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
memory = [
"/AGENTS.md"
],
checkpointer = checkpointer ,
)
result = agent . invoke (
{
"messages" : [
{
"role" : "user" ,
"content" : "Please tell me what's in your memory files." ,
}
],
# 向默认 StateBackend 的状态内文件系统注入初始数据(虚拟路径必须以 "/" 开头)。
"files" : { "/AGENTS.md" : create_file_data ( agents_md )},
},
config = { "configurable" : { "thread_id" : "123456" }},
)
Google
OpenAI
Anthropic
OpenRouter
Fireworks
Baseten
Ollama
from urllib . request import urlopen
from deepagents import create_deep_agent
from deepagents . backends import StoreBackend
from deepagents . backends . utils import create_file_data
from langgraph . store . memory import InMemoryStore
with urlopen (
"https://raw.githubusercontent.com/langchain-ai/deepagents/refs/heads/main/examples/text-to-sql-agent/AGENTS.md"
) as response :
agents_md = response . read (). decode ( "utf-8" )
# 创建 store 并将文件添加到其中
store = InMemoryStore ()
file_data = create_file_data ( agents_md )
store . put (
namespace = ( "filesystem" ,),
key = "/AGENTS.md" ,
value = file_data ,
)
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
backend = StoreBackend (),
store = store ,
memory = [ "/AGENTS.md" ],
)
result = agent . invoke (
{
"messages" : [
{
"role" : "user" ,
"content" : "Please tell me what's in your memory files." ,
}
],
"files" : { "/AGENTS.md" : create_file_data ( agents_md )},
},
config = { "configurable" : { "thread_id" : "12345" }},
)
Google
OpenAI
Anthropic
OpenRouter
Fireworks
Baseten
Ollama
from deepagents import create_deep_agent
from deepagents . backends import FilesystemBackend
from langgraph . checkpoint . memory import MemorySaver
# 人机协作(human-in-the-loop)必须配置 Checkpointer
checkpointer = MemorySaver ()
agent = create_deep_agent (
model = "google_genai:gemini-3.1-pro-preview" ,
backend = FilesystemBackend ( root_dir = "/Users/user/ {project} " ),
memory = [
"./AGENTS.md"
],
interrupt_on = {
"write_file" : True , # 默认:批准、编辑、拒绝
"read_file" : False , # 无需中断
"edit_file" : True , # 默认:批准、编辑、拒绝
},
checkpointer = checkpointer , # 必需!
)
配置文件
Harness 配置文件 封装了按提供商或按模型的调整(系统提示词后缀、工具描述覆盖、排除的工具或 Middleware、额外 Middleware 和通用子 Agent 编辑),使 create_deep_agent 在选择匹配模型时自动应用它们。
from deepagents import HarnessProfile , register_harness_profile
# 当选择 gpt-5.4 时,追加一段系统提示词后缀。
register_harness_profile (
"openai:gpt-5.4" ,
HarnessProfile ( system_prompt_suffix = "Respond in under 100 words." ),
)
参见配置文件 了解注册键、合并语义和插件打包。更窄范围的配套 API 提供商配置文件 封装了提供商的模型构造参数。
结构化输出
Deep Agents 支持结构化输出 。
你可以通过将所需的结构化输出 Schema 作为 response_format 参数传递给 create_deep_agent() 来设置。
当模型生成结构化数据时,它会被捕获、验证并返回在 Deep Agent 状态的 ‘structured_response’ 键中。
import os
from typing import Literal
from pydantic import BaseModel , Field
from tavily import TavilyClient
from deepagents import create_deep_agent
tavily_client = TavilyClient ( api_key = os . environ [ " TAVILY_API_KEY " ])
def internet_search (
query : str ,
max_results : int = 5 ,
topic : Literal [ " general " , " news " , " finance " ] = "general" ,
include_raw_content : bool = False ,
):
"""Run a web search"""
return tavily_client . search (
query ,
max_results = max_results ,
include_raw_content = include_raw_content ,
topic = topic ,
)
class WeatherReport ( BaseModel ):
"""包含当前天气状况和预报的结构化天气报告。"""
location : str = Field ( description = "The location for this weather report" )
temperature : float = Field ( description = "Current temperature in Celsius" )
condition : str = Field (
description = "Current weather condition (e.g., sunny, cloudy, rainy)"
)
humidity : int = Field ( description = "Humidity percentage" )
wind_speed : float = Field ( description = "Wind speed in km/h" )
forecast : str = Field ( description = "Brief forecast for the next 24 hours" )
agent = create_deep_agent (
model = model ,
response_format = WeatherReport ,
tools = [ internet_search ],
)
result = agent . invoke (
{
"messages" : [
{
"role" : "user" ,
"content" : "What's the weather like in San Francisco?" ,
}
]
}
)
print ( result [ " structured_response " ])
# location='San Francisco, California' temperature=18.3 condition='Sunny' humidity=48 wind_speed=7.6 forecast='Pleasant sunny conditions expected to continue with temperatures around 64°F (18°C) during the day, dropping to around 52°F (11°C) at night. Clear skies with minimal precipitation expected.'
更多信息和示例请参阅响应格式 。
连接这些文档 到 Claude、VSCode 等工具,通过 MCP 获取实时答案。