跳到主要内容

五、编写技能

OpenClaw 的技能(Skill)系统是其核心扩展机制——通过编写一个 SKILL.md 文件,你就能让 AI Agent 学会新能力。本附录从零讲解技能的结构、开发流程和发布方式。

推荐工具:Anthropic 官方出品的 skill-creator 是目前最成熟的技能开发辅助工具

agent skill这个网站详细介绍了如何为ai编写skill,最佳规则等。

一、技能是什么?

Skills vs Tools

先分清两个概念:

Tools(工具)Skills(技能)
比喻手脚和权限开关教练
作用决定 Agent 能不能做某类动作告诉Agent如何做一件事
例子文件读写、Shell 执行、网络请求按格式、步骤写稿

技能三级加载

OpenClaw 按优先级从高到低加载技能:

优先级类型位置说明
1工作空间技能~/.openclaw/workspace/skills/当前工作空间专属,优先级最高
2托管技能~/.openclaw/skills/通过 ClawHub 安装的共享技能
3内置技能随 OpenClaw 安装官方捆绑,优先级最低

同名技能按优先级覆盖,采用懒加载策略(用到时才读取 SKILL.md 正文)。


二、技能的结构

每个技能是一个文件夹,核心是 SKILL.md

my-skill/
├── SKILL.md # 必需:技能定义文件(YAML frontmatter + Markdown 指令)
├── scripts/ # 可选:可执行脚本(搜索、API 调用等)
├── references/ # 可选:参考文档(按需加载,不占常驻上下文)
└── assets/ # 可选:模板、图标等静态资源

SKILL.md 格式

SKILL.md 由两部分组成:YAML frontmatter(元数据)+ Markdown 正文(指令)。

---
name: my-skill
description: 技能描述(最重要的字段——AI 根据它决定何时调用此技能)
user-invocable: true
disable-model-invocation: false
metadata:
openclaw:
requires:
env:
- MY_API_KEY
bins:
- node
---

# 技能指令

这里用 Markdown 写清楚 AI 应该怎么使用这个技能。

可以用 `{baseDir}` 引用技能所在目录,OpenClaw 运行时会自动替换为实际路径。

Frontmatter 字段说明

字段必填说明
name技能标识符,小写字母 + 连字符(如 my-awesome-skill
description决定 AI 何时调用此技能——写清楚"做什么"和"什么时候用"
user-invocable是否可通过斜杠命令手动调用(默认 true
disable-model-invocation设为 true 则 AI 不会自动触发,只能手动调用(默认 false
homepage技能或服务的官网链接
metadata.openclaw.requires.env需要的环境变量(未设置时技能标记为"不可用")
metadata.openclaw.requires.bins需要的系统命令(如 nodepythoncurl
metadata.openclaw.requires.config需要的配置路径

三级加载机制

技能内容按需逐级加载,节省上下文窗口:

级别内容何时加载建议大小
1name + description始终在上下文中~100 词
2SKILL.md 正文技能被触发时小于500 行
3references/ 中的文件正文中指示读取时不限

写作建议:SKILL.md 正文控制在 500 行以内。如果内容较多,将详细文档放到 references/ 目录,在正文中用"如需了解 X,请读取 {baseDir}/references/x.md"指引。


三、开发技能

使用对话模式开发

skill-creator 是 Anthropic 官方出品的技能开发辅助工具,它能引导你完成从构思到测试的完整流程。 它本身就是一个 OpenClaw 技能,安装方式与其他技能一致:

# 方式一:通过 ClawHub 安装(推荐)
clawhub install skill-creator

# 方式二:手动安装到工作空间
# 将 skill-creator 文件夹复制到:
# ~/.openclaw/workspace/skills/skill-creator/

安装后,skill-creator 会自动出现在 OpenClaw 的可用技能列表中:

openclaw skills list | grep skill-creator

skill-creator 采用对话式开发——你只需要在聊天中描述想要的技能,它会引导你完成全部步骤:

第一步:描述意图

在 OpenClaw 聊天界面中,直接告诉 Agent 你想做什么:

帮我创建一个天气查询技能

或者更具体地:

我想做一个技能,用户问天气时自动调用和风天气 API 返回实时天气

skill-creator 会通过几个问题帮你明确需求:

  • 这个技能让 Agent 做什么?
  • 什么时候应该触发?(用户说什么话时)
  • 输出是什么格式?
  • 需要测试用例吗?

第二步:自动生成 SKILL.md

skill-creator 根据你的回答自动生成完整的 SKILL.md,包括:

  • frontmatter 元数据(name、description、依赖声明)
  • Markdown 指令正文
  • 需要的脚本文件(如 API 调用脚本)

第三步:测试与迭代

skill-creator 会生成 2-3 个测试用例,模拟真实用户的对话场景,然后:

  1. 用你的技能运行这些测试
  2. 展示测试结果供你审阅
  3. 根据你的反馈改进技能
  4. 重复,直到你满意为止
skill-creator 的完整目录结构
skill-creator/
├── SKILL.md # 技能定义(核心指令,约 480 行)
├── LICENSE.txt # Apache 2.0 许可证
├── agents/ # 专用子代理指令
│ ├── grader.md # 评分代理:评估断言是否通过
│ ├── comparator.md # 比较代理:盲测 A/B 对比
│ └── analyzer.md # 分析代理:解读基准测试结果
├── scripts/ # 自动化脚本
│ ├── run_loop.py # 描述优化主循环
│ ├── run_eval.py # 触发率评估
│ ├── improve_description.py # 描述改进
│ ├── aggregate_benchmark.py # 基准汇总
│ ├── generate_report.py # 报告生成
│ ├── package_skill.py # 技能打包
│ └── quick_validate.py # 快速校验
├── references/
│ └── schemas.md # JSON 数据结构规范
├── assets/
│ └── eval_review.html # 评测结果审阅界面模板
└── eval-viewer/
└── generate_review.py # 可视化评测结果查看器
skill-creator 进阶功能

描述优化(Description Optimization)

description 字段是 AI 决定是否调用技能的唯一依据。skill-creator 内置了自动优化流程:

  1. 生成 20 个测试查询(10 个应触发 + 10 个不应触发)
  2. 在你审阅并确认后,运行优化循环
  3. 自动将评测集拆分为 60% 训练 / 40% 测试
  4. 每轮迭代最多运行 3 次以获取可靠触发率
  5. 最终选择测试集得分最高(而非训练集)的描述,避免过拟合

盲测对比(Blind Comparison)

想严格比较两个版本的技能?skill-creator 支持将两个版本的输出交给独立代理盲评——它不知道哪个是新版、哪个是旧版,只根据质量打分。

基准测试(Benchmarking)

每轮迭代自动生成 benchmark.json,包含:

  • 各断言的通过率
  • 用时和 Token 消耗对比
  • 均值 ± 标准差 + 变化量

手动开发(不使用 skill-creator)

如果你更喜欢手动操作,步骤如下:

  1. 创建目录

    mkdir -p ~/.openclaw/workspace/skills/my-skill
  2. 编写 SKILL.md(参照本附录第二节的格式)

  3. 验证

    openclaw skills check
    openclaw skills info my-skill
  4. 测试:在聊天中发送触发关键词,观察技能是否正常工作。


四、发布到 ClawHub

技能开发完成后,你可以将它发布到 ClawHub 社区,让全世界的 OpenClaw 用户都能安装使用。

发布前准备

确保你的技能文件夹结构完整:

my-skill/
├── SKILL.md # 必需:包含完整的 frontmatter 和指令
├── scripts/ # 可选:脚本文件
└── ... # 其他辅助文件(纯文本)

注意:ClawHub 只接受包含 SKILL.md 和纯文本文件的文件夹。二进制文件、图片等不支持上传。

发布步骤

1. 登录 ClawHub

访问 clawhub.ai,使用 GitHub 账号登录。

2. 进入发布页面

点击页面顶部的 Upload按钮,进入技能发布界面:

ClawHub 技能发布界面

3. 填写发布信息

字段说明示例
Slug技能的 URL 标识符(小写字母 + 连字符)hello-claw
Display name技能显示名称Hello Claw
Version版本号,遵循 语义化版本(SemVer)1.0.0
Tags版本标签,默认 latestlatest

4. 上传技能文件夹

将包含 SKILL.md 的文件夹拖拽到 "Drop a folder" 区域,或点击 "Choose folder" 手动选择。

上传后,页面右侧会显示检测到的 SKILL.md 文件。系统会自动去除外层包裹目录——你只需确保文件夹内有 SKILL.md 即可。

5. 自动校验(Validation)

ClawHub 会自动检查技能是否符合社区规则:

  • SKILL.md 是否存在且格式正确
  • frontmatter 是否包含必需的 namedescription
  • 文件是否为纯文本

校验通过后会显示 "All checks passed"

6. 确认许可证(License)

默认许可证为 MIT-0(MIT No Attribution):

允许任何人免费使用、修改和重新分发,无需署名。

勾选 "I have the rights to this skill and agree to publish it under MIT-0" 确认。

提示:MIT-0 是目前最宽松的开源许可证之一,适合社区共享。如果你的技能包含专有内容,请在发布前确认许可证兼容性。

7. 填写 Changelog(可选)

简要描述这个版本的内容,例如:

Initial release of "Hello Claw Skill" - comprehensive skill mastery framework for OpenClaw ecosystem.

8. 发布

确认无误后,点击右下角的 "Publish skill" 按钮。发布成功后,其他用户即可通过以下命令安装:

clawhub install 你的用户名/my-skill

更新已发布的技能

修改技能后,只需递增版本号并重新上传:

  1. 更新 SKILL.md 中的内容
  2. 在发布页面填写新版本号(如 1.0.01.1.0
  3. 上传更新后的文件夹
  4. 填写 Changelog 说明变更内容
  5. 点击 Publish

用户可通过 clawhub update 获取最新版本。


五、技能管理

CLI 命令

# 查看所有可用技能
openclaw skills list

# 仅显示就绪的技能
openclaw skills list --eligible

# 显示详细信息(包括缺失的依赖)
openclaw skills list -v

# 查看某个技能的详情
openclaw skills info <skill-name>

# 检查所有技能状态
openclaw skills check

通过 ClawHub 安装技能

# 搜索技能
clawhub search <关键词>

# 安装技能
clawhub install <技能名>

# 查看已安装的技能
clawhub list

# 更新技能
clawhub update <技能名>
clawhub update --all

# 卸载技能
clawhub uninstall <技能名>

ClawHub CLI 的完整用法详见附录 A。

在配置中启用技能

编辑 ~/.openclaw/openclaw.json

{
"skills": {
"entries": {
"skill-name": {
"enabled": true
}
}
}
}

配置凭证(SecretRef)

需要 API Key 的技能,推荐使用 SecretRef 安全存储:

{
"skills": {
"entries": {
"tavily": {
"enabled": true,
"apiKey": {
"source": "env",
"provider": "default",
"id": "TAVILY_API_KEY"
}
}
}
}
}

支持的 source 类型:

source说明适用场景
env从环境变量读取最常用,适合本地开发
file从文件读取适合多人共享服务器
exec从命令执行结果读取适合集成密钥管理系统

六、插件开发

对于比技能更复杂的扩展需求(如自定义 Transport、新增 Tool 类型),可以开发插件:

# 列出已安装插件
openclaw plugins list

# 安装插件
openclaw plugins install <path|.tgz|npm-spec>

# 启用/禁用插件
openclaw plugins enable <id>
openclaw plugins disable <id>

# 插件诊断
openclaw plugins doctor

七、故障排查

技能无法加载

# 检查技能状态(会显示缺失的依赖)
openclaw skills check

# 查看详细信息
openclaw skills info <skill-name> -v

# 查看网关日志
openclaw logs --follow

常见原因:

  • 缺少环境变量(metadata.requires.env 中声明的变量未设置)
  • 缺少系统命令(metadata.requires.bins 中声明的命令未安装)
  • SKILL.md 格式错误(frontmatter 缺少 namedescription

技能不触发

  • 检查 description 是否准确描述了触发场景
  • 确认 disable-model-invocation 未设为 true
  • 尝试在描述中增加触发关键词(skill-creator 的描述优化功能可以帮助解决这个问题)

技能权限问题

确保技能目录有正确的读取权限:

# macOS / Linux
chmod -R 755 ~/.openclaw/workspace/skills/my-skill/

八、开发清单

开发技能前,用这份清单逐项确认:

  • SKILL.md frontmatter 包含 namedescription
  • description 清晰描述触发条件和能力(AI 靠这个决定何时调用)
  • 环境变量需求在 metadata.requires.env 中声明
  • 系统命令依赖在 metadata.requires.bins 中声明
  • 脚本输出 Markdown 格式(对 AI 友好)
  • 敏感信息使用环境变量或 SecretRef,不硬编码
  • 错误处理完善(缺少 Key 时 exit(1),API 失败时输出清晰错误)
  • 本地测试通过(openclaw skills check + 实际对话测试)
  • 准备发布时:文件夹只含 SKILL.md 和纯文本文件
最后编辑时间:2026/03/16 09:18