五、编写技能
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 | 否 | 需要的系统命令(如 node、python、curl) |
metadata.openclaw.requires.config | 否 | 需要的配置路径 |
三级加载机制
技能内容按需逐级加载,节省上下文窗口:
| 级别 | 内容 | 何时加载 | 建议大小 |
|---|---|---|---|
| 1 | name + description | 始终在上下文中 | ~100 词 |
| 2 | SKILL.md 正文 | 技能被触发时 | 小于500 行 |
| 3 | references/ 中的文件 | 正文中指示读取时 | 不限 |
写作建议: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 个测试用例,模拟真实用户的对话场景,然后:
- 用你的技能运行这些测试
- 展示测试结果供你审阅
- 根据你的反馈改进技能
- 重复,直到你满意为止
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 内置了自动优化流程:
- 生成 20 个测试查询(10 个应触发 + 10 个不应触发)
- 在你审阅并确认后,运行优化循环
- 自动将评测集拆分为 60% 训练 / 40% 测试
- 每轮迭代最多运行 3 次以获取可靠触发率
- 最终选择测试集得分最高(而非训练集)的描述,避免过拟合
盲测对比(Blind Comparison)
想严格比较两个版本的技能?skill-creator 支持将两个版本的输出交给独立代理盲评——它不知道哪个是新版、哪个是旧版,只根据质量打分。
基准测试(Benchmarking)
每轮迭代自动生成 benchmark.json,包含:
- 各断言的通过率
- 用时和 Token 消耗对比
- 均值 ± 标准差 + 变化量
手动开发(不使用 skill-creator)
如果你更喜欢手动操作,步骤如下:
-
创建目录
mkdir -p ~/.openclaw/workspace/skills/my-skill -
编写 SKILL.md(参照本附录第二节的格式)
-
验证
openclaw skills check
openclaw skills info my-skill -
测试:在聊天中发送触发关键词,观察技能是否正常工作。
四、发布到 ClawHub
技能开发完成后,你可以将它发布到 ClawHub 社区,让全世界的 OpenClaw 用户都能安装使用。
发布前准备
确保你的技能文件夹结构完整:
my-skill/
├── SKILL.md # 必需:包含完整的 frontmatter 和指令
├── scripts/ # 可选:脚本文件
└── ... # 其他辅助文件(纯文本)
注意:ClawHub 只接受包含
SKILL.md和纯文本文件的文件夹。二进制文件、图片等不支持上传。
发布步骤
1. 登录 ClawHub
访问 clawhub.ai,使用 GitHub 账号登录。
2. 进入发布页面
点击页面顶部的 Upload按钮,进入技能发布界面:

3. 填写发布信息
| 字段 | 说明 | 示例 |
|---|---|---|
| Slug | 技能的 URL 标识符(小写字母 + 连字符) | hello-claw |
| Display name | 技能显示名称 | Hello Claw |
| Version | 版本号,遵循 语义化版本(SemVer) | 1.0.0 |
| Tags | 版本标签,默认 latest | latest |
4. 上传技能文件夹
将包含 SKILL.md 的文件夹拖拽到 "Drop a folder" 区域,或点击 "Choose folder" 手动选择。
上传后,页面右侧会显示检测到的 SKILL.md 文件。系统会自动去除外层包裹目录——你只需确保文件夹内有 SKILL.md 即可。
5. 自动校验(Validation)
ClawHub 会自动检查技能是否符合社区规则:
SKILL.md是否存在且格式正确- frontmatter 是否包含必需的
name和description - 文件是否为纯文本
校验通过后会显示 "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
更新已发布的技能
修 改技能后,只需递增版本号并重新上传:
- 更新 SKILL.md 中的内容
- 在发布页面填写新版本号(如
1.0.0→1.1.0) - 上传更新后的文件夹
- 填写 Changelog 说明变更内容
- 点击 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 缺少
name或description)
技能不触发
- 检查
description是否准确描述了触发场景 - 确认
disable-model-invocation未设为true - 尝试在描述中增加触发关键词(skill-creator 的描述优化功能可以帮助解决这个问题)
技能权限问题
确保技能目录有正确的读取权限:
# macOS / Linux
chmod -R 755 ~/.openclaw/workspace/skills/my-skill/
八、开发清单
开发技能前,用这份清单逐项确认:
- SKILL.md frontmatter 包含
name和description -
description清晰描述触发条件和能力(AI 靠这个决定何时调用) - 环境变量需求在
metadata.requires.env中声明 - 系统命令依赖在
metadata.requires.bins中声明 - 脚本输出 Markdown 格式(对 AI 友好)
- 敏感信息使用环境变量或 SecretRef,不硬编码
- 错误处理完善(缺少 Key 时
exit(1),API 失败时输出清晰错误) - 本地测试通过(
openclaw skills check+ 实际对话测试) - 准备发布时:文件夹只含 SKILL.md 和纯文本文件