使用 Skills
Skills(技能)是按需加载的知识文档,用于教会 AigenLabs 如何处理特定任务——从生成 ASCII 艺术到管理 GitHub PR。本指南介绍日常使用方法。
完整技术参考请见 Skills 系统。
查找 Skills
每个 AigenLabs 安装都内置了捆绑的 skills。查看可用列表:
# 在任意聊天会话中:
/skills
# 或通过 CLI:
aigenlabs skills list
输出包含名称和描述的紧凑列表:
ascii-art Generate ASCII art using pyfiglet, cowsay, boxes...
arxiv Search and retrieve academic papers from arXiv...
github-pr-workflow Full PR lifecycle — create branches, commit...
plan Plan mode — inspect context, write a markdown...
excalidraw Create hand-drawn style diagrams using Excalidraw...
搜索 Skill
# 按关键词搜索
/skills search docker
/skills search music
Skills Hub
官方可选 skills(较重或小众、默认未激活的 skills)可通过 Hub 获取:
# 浏览官方可选 skills
/skills browse
# 搜索 Hub
/skills search blockchain
使用 Skill
每个已安装的 skill 自动成为一个斜杠命令。直接输入其名称即可:
# 加载 skill 并指定任务
/ascii-art Make a banner that says "HELLO WORLD"
/plan Design a REST API for a todo app
/github-pr-workflow Create a PR for the auth refactor
# 只输入 skill 名称(不带任务)会加载它并让你描述需求
/excalidraw
你也可以通过自然对话触发 skills——告诉 AigenLabs 使用某个特定 skill,它会通过 skill_view 工具加载。
渐进式加载
Skills 采用 token 高效的加载模式,agent 不会一次性加载所有内容:
skills_list()— 所有 skills 的紧凑列表(约 3k tokens),在会话开始时加载。skill_view(name)— 单个 skill 的完整 SKILL.md 内容,在 agent 判断需要该 skill 时加载。skill_view(name, file_path)— skill 内的特定参考文件,仅在需要时加载。
这意味着 skills 在真正被使用之前不消耗任何 tokens。
从 Hub 安装
官方可选 skills 随 AigenLabs 一起发布,但默认未激活,需显式安装:
# 安装官方可选 skill
aigenlabs skills install official/research/arxiv
# 在聊天会话中从 Hub 安装
/skills install official/creative/songwriting-and-ai-music
# 直接从任意 HTTP(S) URL 安装单文件 SKILL.md
aigenlabs skills install https://sharethis.chat/SKILL.md
/skills install https://example.com/SKILL.md --name my-skill
安装过程:
- skill 目录被复制到
~/.aigenlabs/skills/ - 出现在
skills_list输出中 - 成为可用的斜杠命令
已安装的 skills 在新会话中生效。如需在当前会话中立即使用,可用 /reset 开启新会话,或添加 --now 参数立即使 prompt 缓存失效(下一轮会消耗更多 tokens)。
验证安装
# 确认已安装
aigenlabs skills list | grep arxiv
# 或在聊天中
/skills search arxiv
插件提供的 Skills
插件可以使用命名空间名称(plugin:skill)捆绑自己的 skills,以避免与内置 skills 发生名称冲突。
# 通过限定名称加载插件 skill
skill_view("superpowers:writing-plans")
# 同名的内置 skill 不受影响
skill_view("writing-plans")
插件 skills 不会列在系统 prompt 中,也不出现在 skills_list 中。它们是按需加载的——当你知道某个插件提供了某个 skill 时,显式加载它。加载后,agent 会看到一个横幅,列出同一插件的其他 skills。
关于如何在自己的插件中捆绑 skills,请参见 构建 AigenLabs 插件 → 捆绑 skills。
配置 Skill 设置
部分 skills 在 frontmatter 中声明了所需的配置:
metadata:
aigenlabs:
config:
- key: tenor.api_key
description: "Tenor API key for GIF search"
prompt: "Enter your Tenor API key"
url: "https://developers.google.com/tenor/guides/quickstart"
当带有配置的 skill 首次加载时,AigenLabs 会提示你输入相应值,并将其存储在 config.yaml 的 skills.config.* 下。
通过 CLI 管理 skill 配置:
# 对特定 skill 进行交互式配置
aigenlabs skills config gif-search
# 查看所有 skill 配置
aigenlabs config get skills.config
创建自己的 Skill
Skills 只是带有 YAML frontmatter 的 Markdown 文件,创建一个不超过五分钟。
1. 创建目录
mkdir -p ~/.aigenlabs/skills/my-category/my-skill
2. 编写 SKILL.md
---
name: my-skill
description: Brief description of what this skill does
version: 1.0.0
metadata:
aigenlabs:
tags: [my-tag, automation]
category: my-category
---
# My Skill
## When to Use
Use this skill when the user asks about [specific topic] or needs to [specific task].
## Procedure
1. First, check if [prerequisite] is available
2. Run `command --with-flags`
3. Parse the output and present results
## Pitfalls
- Common failure: [description]. Fix: [solution]
- Watch out for [edge case]
## Verification
Run `check-command` to confirm the result is correct.
3. 添加参考文件(可选)
Skills 可以包含 agent 按需加载的辅助文件:
my-skill/
├── SKILL.md # 主 skill 文档
├── references/
│ ├── api-docs.md # agent 可查阅的 API 参考
│ └── examples.md # 示例输入/输出
├── templates/
│ └── config.yaml # agent 可使用的模板文件
└── scripts/
└── setup.sh # agent 可执行的脚本
在 SKILL.md 中引用这些文件:
For API details, load the reference: `skill_view("my-skill", "references/api-docs.md")`
4. 测试
开启新会话并测试你的 skill:
aigenlabs chat -q "/my-skill help me with the thing"
Skill 会自动出现——无需注册。放入 ~/.aigenlabs/skills/ 即可立即生效。
Agent 也可以使用 skill_manage 自行创建和更新 skills。解决复杂问题后,AigenLabs 可能会主动提议将该方法保存为 skill,以便下次使用。
按平台管理 Skills
控制哪些 skills 在哪些平台上可用:
aigenlabs skills
这会打开一个交互式 TUI,你可以按平台(CLI、Telegram、Discord 等)启用或禁用 skills。当你希望某些 skills 仅在特定场景下可用时非常有用——例如,在 Telegram 上禁用开发类 skills。
Skills 与 Memory 的区别
两者都跨会话持久化,但用途不同:
| Skills | Memory | |
|---|---|---|
| 内容 | 程序性知识——如何做事 | 事实性知识——事物是什么 |
| 时机 | 按需加载,仅在相关时加载 | 自动注入每个会话 |
| 大小 | 可以较大(数百行) | 应保持紧凑(仅关键事实) |
| 开销 | 加载前零 tokens | 少量但持续的 token 开销 |
| 示例 | "如何部署到 Kubernetes" | "用户偏好深色模式,位于 PST 时区" |
| 创建者 | 你、agent 或从 Hub 安装 | Agent,基于对话内容 |
经验法则: 如果你会把它写进参考文档,它就是 skill;如果你会把它写在便利贴上,它就是 memory。
使用技巧
保持 skills 聚焦。 试图涵盖"所有 DevOps"的 skill 会过于冗长且模糊。专注于"将 Python 应用部署到 Fly.io"的 skill 才足够具体,真正有用。
让 agent 创建 skills。 完成复杂的多步骤任务后,AigenLabs 通常会主动提议将该方法保存为 skill。接受它——这些由 agent 编写的 skills 会捕捉到完整的工作流程,包括过程中发现的各种坑。
使用分类目录。 将 skills 整理到子目录中(~/.aigenlabs/skills/devops/、~/.aigenlabs/skills/research/ 等),保持列表整洁,并帮助 agent 更快找到相关 skills。
及时更新过时的 skills。 如果使用某个 skill 时遇到它未覆盖的问题,告诉 AigenLabs 用你学到的内容更新该 skill。不维护的 skills 会成为负担。
完整的 skills 参考——frontmatter 字段、条件激活、外部目录等——请见 Skills 系统。