技能创建涉及这些步骤:
- 通过具体示例理解技能
- 规划可重用的技能内容(脚本、参考资料、资产)
- 初始化技能(运行init_skill.ts)
- 编辑技能(实现资源和编写SKILL.md)
- 打包技能(运行package_skill.ts)
- 基于实际使用进行迭代
按顺序遵循这些步骤,只有在明确原因不适用的前提下才能跳过。
步骤1:通过具体示例理解技能
只有在技能的使用模式已经清楚理解时才跳过此步骤。即使在处理现有技能时,这一步仍然有价值。
要创建有效的技能,清楚了解技能将如何使用的具体示例。这种理解可以来自直接的用户示例或通过用户反馈验证的生成示例。
例如,在构建image-editor技能时,相关问题包括:
- "image-editor技能应该支持什么功能?编辑、旋转,还是其他?"
- "你能给出一些如何使用这个技能的示例吗?"
- "我可以想象用户要求像'从这张图片中去除红眼'或'旋转这张图片'之类的事情。你能想象这个技能的其他使用方式吗?"
- "用户会说些什么来触发这个技能?"
为了避免压倒用户,避免在单条消息中问太多问题。从最重要的问题开始,根据需要跟进以获得更好的效果。
当清楚地了解技能应该支持的功能时结束此步骤。
步骤2:规划可重用的技能内容
要将具体示例转化为有效技能,通过以下方式分析每个示例:
- 考虑如何从头开始执行示例
- 识别在重复执行这些工作流程时哪些脚本、参考资料和资产会有帮助
示例:当构建pdf-editor技能来处理像"帮我旋转这个PDF"这样的查询时,分析显示:
- 旋转PDF每次都需要重写相同的代码
- 一个
scripts/rotate_pdf.ts脚本会很有帮助,可以存储在技能中
示例:当设计frontend-webapp-builder技能来处理像"为我构建一个todo应用"或"为我构建一个跟踪步数的仪表板"这样的查询时,分析显示:
- 编写前端webapp每次都需要相同的样板HTML/React
- 一个包含样板HTML/React项目文件的
assets/hello-world/模板会很有帮助,可以存储在技能中
示例:当构建big-query技能来处理像"今天有多少用户登录?"这样的查询时,分析显示:
- 查询BigQuery每次都需要重新发现表模式和关系
- 一个记录表模式的
references/schema.md文件会很有帮助,可以存储在技能中
要建立技能的内容,分析每个具体示例以创建要包含的可重用资源列表:脚本、参考资料和资产。
步骤3:初始化技能
此时,是时候实际创建技能了。
只有在正在开发的技能已经存在,并且需要迭代或打包时才跳过此步骤。在这种情况下,继续下一步。
从零开始创建新技能时,始终运行init_skill.ts脚本。该脚本方便地生成一个新的模板技能目录,自动包含技能所需的一切,使技能创建过程更加高效和可靠。
用法:
```bash
npx ts-node .claude/skills/skill-creator/scripts/init_skill.ts --path
```
该脚本:
- 在指定路径创建技能目录
- 生成带有适当前置元数据和TODO占位符的SKILL.md模板
- 创建示例资源目录:
scripts/、references/和assets/ - 在每个目录中添加可以自定义或删除的示例文件
初始化后,根据需要自定义或删除生成的SKILL.md和示例文件。
步骤4:编辑技能
在编辑(新生成的或现有的)技能时,记住技能是为另一个Claude实例创建的。包含对Claude有益且不明显的信息。考虑什么过程性知识、领域特定细节或可重用资产会帮助另一个Claude实例更有效地执行这些任务。
#### 学习经过验证的设计模式
根据技能的需要参考这些有用的指南:
- 多步骤过程:有关顺序工作流程和条件逻辑,参见references/workflows.md
- 特定输出格式或质量标准:有关模板和示例模式,参见references/output-patterns.md
这些文件包含有效技能设计的既定最佳实践。
#### 从可重用的技能内容开始
开始实现时,从上面确定的可重用资源开始:scripts/、references/和assets/文件。请注意,此步骤可能需要用户输入。例如,在实现brand-guidelines技能时,用户可能需要提供要存储在assets/中的品牌资产或模板,或要存储在references/中的文档。
添加的脚本必须通过实际运行来测试,以确保没有错误且输出符合预期。如果有许多类似的脚本,只需要测试代表性样本以确保对它们都有信心,同时平衡完成时间。
技能不需要的任何示例文件和目录都应该删除。初始化脚本在scripts/、references/和assets/中创建示例文件以演示结构,但大多数技能不会需要所有这些。
#### 更新SKILL.md
写作指导原则: 始终使用命令式/不定式形式。
##### 前置元数据
编写带有name和description的YAML前置元数据:
name:技能名称description:这是技能的主要触发机制,帮助Claude理解何时使用技能。
- 包括技能做什么以及何时使用的特定触发器/上下文。
- 在这里包含所有"何时使用"信息 - 不要在正文中。正文只在触发后加载,所以正文中的"何时使用此技能"部分对Claude没有帮助。
- docx技能的描述示例:"支持修订跟踪、注释、格式保持和文本提取的综合文档创建、编辑和分析。当Claude需要处理专业文档(.docx文件)时使用:(1) 创建新文档,(2) 修改或编辑内容,(3) 处理修订跟踪,(4) 添加注释,或任何其他文档任务"
不要在YAML前置元数据中包含任何其他字段。
##### 正文
编写使用技能及其references的指令。
步骤5:打包技能
一旦技能开发完成,必须将其打包成可分发的.skill文件,与用户共享。打包过程首先自动验证技能以确保满足所有要求:
```bash
npx ts-node .claude/skills/skill-creator/scripts/package_skill.ts
```
可选输出目录规范:
```bash
npx ts-node .claude/skills/skill-creator/scripts/package_skill.ts ./dist
```
打包脚本将:
- 自动验证技能,检查:
- YAML前置元数据格式和必需字段
- 技能命名约定和目录结构
- 描述的完整性和质量
- 文件组织和资源引用
- 如果验证通过,打包技能,创建以技能命名的.skill文件(例如,
my-skill.skill),包含所有文件并保持适当的目录结构以供分发。.skill文件是带有.skill扩展名的zip文件。
如果验证失败,脚本将报告错误并退出而不创建包。修复任何验证错误并再次运行打包命令。
步骤6:迭代
测试技能后,用户可能要求改进。这通常在使用技能后立即发生,对技能的表现有新鲜的上下文。
迭代工作流程:
- 在实际任务上使用技能
- 注意到困难或效率低下
- 识别SKILL.md或references应该如何更新
- 实施更改并再次测试