跳到主要内容

规范

目录结构

一个 skill 是一个目录,至少包含一个 SKILL.md 文件:

skill-name/
├── SKILL.md # 必填:元数据 + 指令
├── scripts/ # 可选:可执行代码
├── references/ # 可选:文档
├── assets/ # 可选:模板、资源
└── ... # 任何其他文件或目录

SKILL.md 格式

SKILL.md 文件必须包含 YAML frontmatter(前置元数据),其后紧跟 Markdown 内容。

Frontmatter

字段是否必填约束条件
name最多 64 个字符。仅限小写字母、数字和连字符。不能以连字符开头或结尾。
description最多 1024 个字符。非空。描述该 skill 的功能以及何时使用它。
license许可证名称或对捆绑的许可证文件的引用。
compatibility最多 500 个字符。指示环境要求(目标产品、系统包、网络访问等)。
metadata用于附加元数据的任意键值对映射。
allowed-tools该 skill 可以使用的预先批准的工具的空格分隔列表。(实验性)

最小示例:

---
name: skill-name
description: 描述该 skill 的功能以及何时使用它。
---

包含可选字段的示例:

---
name: pdf-processing
description: 提取 PDF 文本、填写表单、合并文件。在处理 PDF 时使用。
license: Apache-2.0
metadata:
author: example-org
version: "1.0"
---

name 字段

必填的 name 字段:

  • 长度必须为 1-64 个字符
  • 只能包含 Unicode 小写字母数字字符(a-z)和连字符(-
  • 不能以连字符(-)开头或结尾
  • 不能包含连续的连字符(--
  • 必须与父目录名称匹配

有效示例:

name: pdf-processing
name: data-analysis
name: code-review

无效示例:

name: PDF-Processing  # 不允许使用大写字母
name: -pdf  # 不能以连字符开头
name: pdf--processing  # 不允许使用连续的连字符

description 字段

必填的 description 字段:

  • 长度必须为 1-1024 个字符
  • 应描述该 skill 的功能以及何时使用它
  • 应包含有助于 Agent 识别相关任务的特定关键字

好的示例:

description: 从 PDF 文件中提取文本和表格,填写 PDF 表单,并合并多个 PDF。在处理 PDF 文档或用户提及 PDF、表单或文档提取时使用。

差的示例:

description: 帮助处理 PDF。

license 字段

可选的 license 字段:

  • 指定应用于该 skill 的许可证
  • 我们建议保持简短(许可证的名称或捆绑的许可证文件的名称)

示例:

license: Proprietary. LICENSE.txt 包含完整条款

compatibility 字段

可选的 compatibility 字段:

  • 如果提供,长度必须为 1-500 个字符
  • 仅当您的 skill 有特定的环境要求时才应包含
  • 可以指示目标产品、所需的系统包、网络访问需求等

示例:

compatibility: 专为 Claude Code(或类似产品)设计
compatibility: 需要 git、docker、jq 以及互联网访问权限

大多数 Skills 不需要 compatibility 字段。

metadata 字段

可选的 metadata 字段:

  • 从字符串键到字符串值的映射
  • 客户端可以使用它来存储 Agent Skills 规范未定义的附加属性
  • 我们建议使您的键名保持合理的唯一性,以避免意外冲突

示例:

metadata:
author: example-org
version: "1.0"

allowed-tools 字段

可选的 allowed-tools 字段:

  • 预先批准运行的工具的空格分隔列表
  • 实验性。不同 Agent 实现对该字段的支持可能有所不同

示例:

allowed-tools: Bash(git:*) Bash(jq:*) Read

正文内容

Frontmatter 之后的 Markdown 正文包含 skill 指令。没有任何格式限制。编写任何有助于 Agent 有效执行任务的内容。

推荐的章节:

  • 分步指令
  • 输入和输出示例
  • 常见边缘情况

请注意,一旦 Agent 决定激活某个 skill,它将加载整个文件。考虑将较长的 SKILL.md 内容拆分到引用的文件中。

可选目录

scripts/

包含 Agent 可以运行的可执行代码。脚本应该:

  • 保持独立或清晰地记录依赖项
  • 包含有用的错误消息
  • 优雅地处理边缘情况

支持的语言取决于 Agent 的实现。常见的选项包括 Python、Bash 和 JavaScript。

references/

包含 Agent 在需要时可以阅读的附加文档:

  • REFERENCE.md - 详细的技术参考
  • FORMS.md - 表单模板或结构化数据格式
  • 特定领域的文件(finance.mdlegal.md 等)

保持各个参考文件的专注度。Agent 会按需加载这些文件,因此较小的文件意味着占用更少的上下文。

assets/

包含静态资源:

  • 模板(文档模板、配置模板)
  • 图像(图表、示例)
  • 数据文件(查找表、模式)

渐进式披露

Skills 的结构设计应旨在高效利用上下文:

  1. 元数据(约 100 tokens):所有 skills 的 namedescription 字段在启动时加载
  2. 指令(建议 < 5000 tokens):完整的 SKILL.md 正文在 skill 被激活时加载
  3. 资源(按需):文件(例如 scripts/references/assets/ 中的文件)仅在需要时加载

保持主 SKILL.md 在 500 行以内。将详细的参考资料移至单独的文件中。

文件引用

在您的 skill 中引用其他文件时,请使用相对于 skill 根目录的相对路径:

有关详细信息,请参阅[参考指南](references/REFERENCE.md)

运行提取脚本:
scripts/extract.py

保持文件引用距离 SKILL.md 只有一层深度。避免深度嵌套的引用链。

验证

使用 skills-ref 参考库来验证您的 skills:

skills-ref validate ./my-skill

这将检查您的 SKILL.md frontmatter 是否有效并遵循所有命名约定。