Documentation Index
Fetch the complete documentation index at: https://agent-skills.zhcndoc.com/llms.txt
Use this file to discover all available pages before exploring further.
从真正的专业知识开始
技能创建中的一个常见陷阱是要求 LLM 生成技能却不提供特定领域的上下文——仅依赖 LLM 的通用训练知识。结果是模糊、通用的过程(“适当处理错误”、“遵循最佳身份验证实践”),而不是使技能具有价值的具体 API 模式、边缘情况和项目约定。 有效的技能植根于真正的专业知识。关键是将特定领域的上下文馈送到创建过程中。从实际操作任务中提取
与代理对话完成实际任务,在此过程中提供上下文、修正和偏好。然后将可重用的模式提取到技能中。注意:- 有效的步骤 — 导致成功的动作序列
- 你做出的修正 — 你引导代理方法的地方(例如,“使用库 X 而不是 Y”,“检查边缘情况 Z”)
- 输入/输出格式 — 数据进入和出来时的样子
- 你提供的上下文 — 代理尚未知道的项目特定事实、约定或约束
从现有项目工件中综合
当你拥有现有知识体系时,你可以将其馈送到 LLM 并要求它综合出一个技能。从团队实际事件报告和运行手册综合出的数据管道技能将优于从通用“数据工程最佳实践”文章综合出的技能,因为它捕捉了你的模式、故障模式和恢复过程。关键是项目特定材料,而不是通用参考。 良好的源材料包括:- 内部文档、运行手册和风格指南
- API 规范、模式和配置文件
- 代码审查评论和问题跟踪器(捕捉重复出现的关切点和审查者期望)
- 版本控制历史,尤其是补丁和修复(通过实际变更揭示模式)
- 现实世界的失败案例及其解决方案
通过实际执行进行优化
技能的初稿通常需要优化。针对实际任务运行技能,然后将结果——所有结果,而不仅仅是失败——反馈到创建过程中。询问:什么触发了误报?什么被遗漏了?什么可以削减? 即使只进行一次执行后修订的循环也能显著提高质量,复杂领域通常受益于多次循环。 有关更结构化的迭代方法,包括测试用例、断言和评分,请参阅 评估技能输出质量。明智地使用上下文
一旦技能激活,其完整的SKILL.md 主体会与对话历史、系统上下文和其他活动技能一起加载到代理的上下文窗口中。技能中的每个 token 都在与该窗口中的其他所有内容争夺代理的注意力。
添加代理缺乏的内容,省略它已知的内容
专注于代理在没有你的技能的情况下不会知道的内容:项目特定约定、特定领域过程、不明显的边缘情况,以及要使用的特定工具或 API。你不需要解释什么是 PDF、HTTP 如何工作,或数据库迁移做什么。设计连贯的单元
决定技能应涵盖的内容就像决定函数应做什么:你希望它封装一个连贯的工作单元,并能与其他技能良好组合。范围过窄的技能迫使单个任务加载多个技能,冒着开销和冲突指令的风险。范围过宽的技能变得难以精确激活。查询数据库并格式化结果的技能可能是一个连贯的单元,而同时也涵盖数据库管理的技能可能试图做得太多。旨在适度细节
过于全面的技能弊大于利——代理难以提取相关内容,并且可能会追求由不适用于当前任务的指令触发的无效路径。简洁的、分步的指导配合工作示例往往优于详尽的文档。当你发现自己涵盖每个边缘情况时,考虑是否大多数最好由代理自己的判断来处理。使用渐进式披露构建大型技能
规范 建议将SKILL.md 保持在 500 行和 5,000 个 token 以下——仅需代理每次运行所需的核心指令。当技能确实需要更多内容时,将详细的参考材料移动到 references/ 或类似目录中的单独文件中。
关键是告诉代理何时加载每个文件。“如果 API 返回非 200 状态码,请阅读 references/api-errors.md”比泛泛地说“有关详细信息请参见 references/”更有用。这使代理能够按需加载上下文,而不是预先全部加载,这正是 渐进式披露 的设计目标。
校准控制
并非技能的每个部分都需要相同级别的规定性。使指令的具体性与任务的脆弱性相匹配。使具体性与脆弱性相匹配
给予代理自由,当多种方法有效且任务容许变化时。对于灵活的指令,解释为什么比僵化的指令更有效——理解指令背后目的的代理能做出更好的上下文相关决策。代码审查技能可以描述要查找的内容而不规定确切步骤:提供默认值,而非菜单
当多种工具或方法可行时,选择一个默认值并简要提及替代方案,而不是将它们作为平等选项呈现。倾向于过程而非声明
技能应该教代理如何处理一类问题,而不是为特定实例生产什么。比较:有效指令的模式
这些是构建技能内容的可重用技术。并非每个技能都需要所有这些——使用适合你任务的技术。陷阱部分
许多技能中价值最高的内容是一列陷阱——违背合理假设的特定于环境的事实。这些不是一般性建议(“适当处理错误”),而是对代理在不被告知的情况下会犯的错误的具体纠正:SKILL.md 中,代理在遇到情况之前会阅读它们。如果你告诉代理何时加载它,单独的参考文件也可以,但对于不明显的问题,代理可能无法识别触发器。
输出格式模板
当你需要代理以特定格式生成输出时,提供模板。这比用散文描述格式更可靠,因为代理能很好地对具体结构进行模式匹配。短模板可以内联生活在SKILL.md 中;对于较长的模板,或仅在某些情况下需要的模板,将它们存储在 assets/ 中并从 SKILL.md 引用,以便它们仅在需要时加载。
多步骤工作流的清单
明确的清单帮助代理跟踪进度并避免跳过步骤,特别是当步骤有依赖关系或验证门时。验证循环
指示代理在继续之前验证自己的工作。模式是:开展工作,运行验证器(脚本、参考清单或自我检查),修复任何问题,并重复直到验证通过。计划 - 验证 - 执行
对于批量或破坏性操作,让代理以结构化格式创建中间计划,对照真实来源验证,然后才执行。form_fields.json)检查计划(field_values.json)。像“字段 ‘signature_date’ 未找到 — 可用字段:customer_name, order_total, signature_date_signed”这样的错误能为代理提供足够的信息进行自我纠正。
捆绑可重用脚本
当 迭代技能 时,比较测试用例之间的代理执行轨迹。如果你注意到代理每次运行都独立地重新发明相同的逻辑——构建图表、解析特定格式、验证输出——那是一个信号,表明应该编写一个经过测试的脚本一次并将其捆绑在scripts/ 中。
有关设计和捆绑脚本的更多信息,请参阅 在技能中使用脚本。