技能是可复用的智能体能力,提供专门的工作流和领域知识。 你可以使用 Agent Skills 为你的深度智能体提供新的能力和专业知识。要获取现成的技能以提升你的智能体在 LangChain 生态系统任务上的表现,请参阅 LangChain Skills 仓库。 深度智能体技能遵循 Agent Skills 规范,并增加了解释器技能的额外功能,使得可以为技能提供解释器可以调用的可导入函数。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.
什么是技能
技能是一组文件夹目录,每个文件夹包含一个或多个智能体可以使用的上下文文件:- 一个
SKILL.md文件,包含技能的指令和元数据 - 额外的脚本(可选)
- 额外的参考信息,如文档(可选)
- 额外的资源,如模板和其他资源(可选)
任何额外的资源(脚本、文档、模板或其他资源)必须在
SKILL.md 文件中引用,说明文件的内容和使用方式,以便智能体能够决定何时使用它们。技能的工作原理
当你创建深度智能体时,可以传入一个包含技能的目录列表。智能体启动时,会读取每个SKILL.md 文件的 frontmatter。
当智能体接收到提示时,它会检查在满足提示的过程中是否可以使用任何技能。如果找到匹配的提示,它会查看技能文件的其余内容。这种仅在需要时才查看技能信息的模式称为渐进式披露。
示例
你可能有一个技能文件夹,包含一个以特定方式使用文档站点的技能,以及另一个搜索 arXiv 预印本研究论文库的技能:SKILL.md 文件始终遵循相同的模式,以 frontmatter 中的元数据开头,后跟技能的指令。
以下示例展示了一个在收到提示时提供相关 LangGraph 文档指导的技能:
index.ts 中:
完整示例
以下示例展示了使用所有可用 frontmatter 字段的SKILL.md 文件:
用法
创建深度智能体时传入技能目录:- StateBackend
- StoreBackend
- FilesystemBackend
技能源路径列表。路径必须使用正斜杠指定,相对于后端的根目录。
- 如果省略,不加载任何技能。
- 使用
StateBackend(默认)时,通过invoke(files={...})提供技能文件。使用deepagents.backends.utils中的create_file_data()格式化文件内容;不支持原始字符串。 - 使用
FilesystemBackend时,技能从相对于后端root_dir的磁盘加载。
SDK 只加载你在
skills 中传入的源。它不会自动扫描 CLI 目录,如 ~/.deepagents/... 或 ~/.agents/...。有关 CLI 存储约定,请参阅应用数据。在 SDK 中模拟 CLI 源顺序
在 SDK 中模拟 CLI 源顺序
如果你想在 SDK 代码中实现 CLI 风格的分层,请按从低到高优先级的顺序显式传入所有所需的源:然后将该有序列表作为
skills 传入创建智能体。源优先级
当多个技能源包含同名技能时,skills 数组中后列出的源的技能优先(后者优先)。这让你可以从不同来源分层技能。
子智能体的技能
使用子智能体时,你可以配置每种类型可以访问哪些技能:- 通用子智能体:当你向
create_deep_agent传入skills时,自动继承主智能体的技能。无需额外配置。 - 自定义子智能体:不继承主智能体的技能。在每个子智能体定义中添加
skills参数,指定该子智能体的技能源路径。
智能体看到的内容
配置技能后,“技能系统”部分会被注入到智能体的系统提示词中。智能体使用这些信息遵循三步流程:- 匹配——当用户提示到达时,智能体检查是否有技能的描述与任务匹配。
- 读取——如果某个技能适用,智能体使用其技能列表中显示的路径读取完整的
SKILL.md文件。 - 执行——智能体遵循技能的指令并根据需要访问任何支持文件(脚本、模板、参考文档)。
使用技能执行代码
技能支持两种代码执行方式:- 使用解释器技能——当智能体需要从解释器代码中使用可复用的可导入辅助函数时。
- 在沙箱中执行技能脚本——当智能体需要安装依赖、运行测试、调用 CLI 或使用操作系统文件系统时。
使用解释器技能
解释器技能是向解释器暴露代码模块的技能。常规技能为智能体提供指令和上下文。解释器技能还为智能体提供可从解释器代码中调用的可导入函数。 这让你可以将领域特定的逻辑打包一次,并在智能体的工作空间中作为确定性的构建块使用。智能体可以导入经过测试的辅助函数并与工具、子智能体和运行时状态组合,而非要求模型从头重新创建解析器、评分器、规范化器、验证器或聚合程序。 当代码需要以下特性时,请使用解释器技能:- 可复用——跨提示、智能体或项目使用。
- 确定性——每次都需要相同的行为。
- 过于详细——不适合作为指令保留在模型上下文中。
- 在更大工作流中有用——如对搜索结果评分、规范化 API 响应、验证记录、分组行,或将数据转换为可报告的格式。
最小技能目录结构:
在沙箱中执行技能脚本
技能可以在SKILL.md 文件旁包含脚本,例如执行搜索或数据转换的 Python 文件。智能体可以从任何后端 读取 这些脚本,但要 执行 它们,智能体需要访问 shell——只有沙箱后端才提供。
当你使用 CompositeBackend 将技能路由到 StoreBackend 进行持久化,同时使用沙箱作为默认后端时,技能文件存在于 store 中而非沙箱中,而代码在沙箱中运行。为了让沙箱能够使用这些脚本,你必须使用自定义中间件在智能体启动前将技能脚本上传到沙箱中:
before_agent 钩子在每次智能体调用前运行,从共享命名空间读取技能文件并将它们上传到沙箱文件系统中。同步完成后,智能体可以使用 execute 工具像沙箱中的任何其他文件一样执行脚本。
有关还包含双向同步记忆的更完整示例,请参阅使用自定义中间件同步技能和记忆。
技能 vs. 记忆
技能和记忆(AGENTS.md 文件)服务于不同的目的:
| 技能 | 记忆 | |
|---|---|---|
| 用途 | 通过渐进式披露发现的按需能力 | 启动时始终加载的持久上下文 |
| 加载方式 | 仅在智能体判断相关时读取 | 始终注入系统提示词 |
| 格式 | 命名目录中的 SKILL.md | AGENTS.md 文件 |
| 分层 | 用户 → 项目(后者优先) | 用户 → 项目(合并) |
| 使用场景 | 指令针对特定任务且可能很大时 | 上下文始终相关时(项目规范、偏好) |
何时使用技能和工具
以下是使用工具和技能的一些通用指南:- 当有大量上下文时使用技能,以减少系统提示词中的 Token 数。
- 使用技能将能力打包成更大的操作并提供超出单个工具描述的额外上下文。
- 如果智能体无法访问文件系统,则使用工具。
连接这些文档 到 Claude、VSCode 等工具,通过 MCP 获取实时解答。

