Agent Skills
Agent Skills 是 Kimi Code CLI 扩展模型能力的轻量机制。一个 Skill 就是一份带 YAML frontmatter 的 Markdown 文档,描述某项专业知识或工作流程——例如项目的代码风格规范、PR review 流程、提交消息格式。
相比每次把同样的指引粘到提示词里,Skill 的优势在于:内容沉淀在文件里、可以跨项目和团队复用、可以通过斜杠命令一键加载,也可以让模型在需要时自动调用。
创建 Skill
Skill 文件需放在已知的扫描目录中。支持两种文件结构:
- 目录形式(推荐):在 Skills 目录下创建一个子目录,主文件命名为
SKILL.md,可在同目录下放置脚本、参考资料等辅助文件。同目录下同时存在<name>/SKILL.md和同名<name>.md时,以子目录为准。 - 扁平形式:直接使用单个
.md文件,Skill 名称取文件名(去掉.md)。
文件格式
SKILL.md 由 YAML frontmatter 和 Markdown 正文两部分组成:
---
name: code-style
description: 项目代码风格规范,定义命名、缩进、注释和文件组织
type: prompt
whenToUse: 当用户让我编写、修改或审查项目源代码时
disableModelInvocation: false
arguments:
- target
- mode
---
请按下述规范处理代码:
- 缩进使用 2 空格
- 变量名使用 `camelCase`,类型名使用 `PascalCase`
- 公开函数必须带 TSDoc 注释
- 单行不超过 100 字符Frontmatter 字段
| 字段 | 说明 |
|---|---|
name | Skill 名称。目录型 SKILL.md 中为必填;扁平 .md 文件省略时使用文件名。名称大小写不敏感 |
description | 一行总结,模型用它来判断何时使用这个 Skill。目录型 SKILL.md 中为必填;扁平 .md 文件省略时回退到正文第一行非空内容(截至 240 字符) |
type | Skill 类型:prompt(默认)、inline(与 prompt 语义相同)、flow(只支持手动调用,不支持模型自动调用)。其他值会被跳过 |
whenToUse | 触发场景描述。也接受 when-to-use、when_to_use 写法 |
disableModelInvocation | 设为 true 时禁止模型自动调用此 Skill。也接受 disable-model-invocation、disable_model_invocation 写法 |
arguments | 命名参数列表,可写成字符串数组或空白分隔的字符串(如 arguments: target mode)。声明后,正文可用 $<name> 读取参数 |
注意
目录型 SKILL.md 中 name 和 description 必须显式填写,省略任意一项均会导致解析失败。
正文占位符
正文在发送给模型前会展开少量占位符:
$ARGUMENTS:调用时附带的完整原始参数字符串$ARGUMENTS[0]、$ARGUMENTS[1]及简写$0、$1:按空白分词后的位置参数(从 0 开始)$<name>:arguments中声明的命名参数${KIMI_SKILL_DIR}:当前 Skill 文件所在目录
位置参数支持单双引号包裹,如 /skill:commit "fix login" patch 中 $0 展开为 fix login。若正文不含任何参数占位符,调用时附带的文本会以 \n\nARGUMENTS: <文本> 的形式追加到正文末尾。
Skill 存放位置
Kimi Code CLI 按作用域分四档扫描,越具体的作用域优先级越高:Project > User > Extra > Built-in
用户级(对所有项目生效):
~/.kimi-code/skills/~/.agents/skills/
项目级(项目根 = 工作目录向上最近的含 .git 的目录):
.kimi-code/skills/.agents/skills/
额外目录:通过 config.toml 顶层的 extra_skill_dirs 声明:
extra_skill_dirs = ["~/team-skills", ".agents/team-skills"]内置 Skills 随 CLI 一起分发,优先级最低。
调用 Skill
用户通过斜杠命令主动调用:
/skill:code-style
/skill:git-commits 修复登录接口的并发问题模型也可以根据 description 和 whenToUse 自动调用 Skill(除非 disableModelInvocation 设为 true 或 type 为 flow)。Skill 调用时最多允许嵌套 3 层,超过后会被终止。
完整示例
---
name: review-pr
description: 按团队标准审查一个 Pull Request,输出结构化的 review 报告
type: prompt
whenToUse: 当用户让我审查 PR、检查代码变更或评估提交质量时
arguments:
- pr_ref
---
请按照以下流程审查用户指定的 PR:$pr_ref
1. 拉取并阅读 `$pr_ref` 的全部 diff。
2. 对照以下检查项逐条核对:
- 是否包含对应的测试用例
- 公开 API 是否有文档更新
- 是否引入了新的依赖;若有,说明引入理由
- 错误处理是否覆盖了边界情况
3. 参考同目录下的检查清单:`references/checklist.md`
4. 输出一份 review 报告,包含:
- 总体结论(approve / request changes / comment)
- 必须修改项(blocking)
- 建议改进项(non-blocking)
- 值得肯定的地方保存为 ~/.kimi-code/skills/review-pr/SKILL.md,检查清单放在同目录的 references/checklist.md,重开会话后即可通过 /skill:review-pr #1234 调用,其中 #1234 会展开到 $pr_ref。
下一步
- Plugins — 把 Skills 打包成可安装单元,与团队共享
- Agent 与子 Agent — Skills 如何影响子 Agent 的行为