本指南解释了如何为 AI 智能体或开发工具添加技能支持。

集成方法

集成技能的两种主要方法是:

基于文件系统的智能体在计算机环境(bash/unix)内运行,代表最强大的选项。当模型发出 shell 命令(如 cat /path/to/my-skill/SKILL.md)时,技能会被激活。通过 shell 命令访问捆绑的资源。

基于工具的智能体在没有专用计算机环境的情况下运行。相反,它们实现允许模型触发技能和访问捆绑资源的工具。具体的工具实现由开发人员决定。

概述

技能兼容的智能体需要:

  1. 发现配置目录中的技能
  2. 加载元数据(名称和描述)在启动时
  3. 匹配用户任务到相关技能
  4. 激活通过加载完整指令来激活技能
  5. 执行根据需要执行脚本和访问资源

技能发现

技能是包含 SKILL.md 文件的文件夹。您的智能体应该扫描配置的目录以查找有效技能。

加载元数据

启动时,仅解析每个 SKILL.md 文件的 frontmatter。这使初始上下文使用保持较低。

解析 frontmatter

function parseMetadata(skillPath):
    content = readFile(skillPath + "/SKILL.md")
    frontmatter = extractYAMLFrontmatter(content)

    return {
        name: frontmatter.name,
        description: frontmatter.description,
        path: skillPath
    }

注入到上下文

在系统提示中包含技能元数据,以便模型知道有哪些技能可用。

遵循您平台的系统提示更新指南。例如,对于 Claude 模型,推荐的格式使用 XML:

<available_skills>
  <skill>
    <name>pdf-processing</name>
    <description>从 PDF 文件中提取文本和表格,填写表单,合并文档。</description>
    <location>/path/to/skills/pdf-processing/SKILL.md</location>
  </skill>
  <skill>
    <name>data-analysis</name>
    <description>分析数据集,生成图表,并创建摘要报告。</description>
    <location>/path/to/skills/data-analysis/SKILL.md</location>
  </skill>
</available_skills>

对于基于文件系统的智能体,包含 location 字段,其中包含 SKILL.md 文件的绝对路径。对于基于工具的智能体,可以省略位置。

保持元数据简洁。每个技能应该向上下文添加大约 50-100 个 token。

安全考虑

脚本执行会带来安全风险。考虑:

参考实现

skills-ref 库提供了用于处理技能的 Python 实用程序和 CLI。

例如:

验证技能目录:

skills-ref validate <path>

为智能体提示生成 <available_skills> XML:

skills-ref to-prompt <path>...

使用库源代码作为参考实现。