SKILL.md с инструкциями, и Claude добавит его в свой набор инструментов. Claude использует skills при необходимости, или вы можете вызвать один напрямую с помощью /skill-name.
Для встроенных команд, таких как
/help и /compact, см. справочник встроенных команд.Пользовательские команды были объединены с skills. Файл в .claude/commands/deploy.md и skill в .claude/skills/deploy/SKILL.md оба создают /deploy и работают одинаково. Ваши существующие файлы .claude/commands/ продолжают работать. Skills добавляют дополнительные функции: каталог для вспомогательных файлов, frontmatter для управления тем, кто вызывает skill, и возможность для Claude загружать их автоматически при необходимости.Встроенные skills
Встроенные skills поставляются с Claude Code и доступны в каждой сессии. В отличие от встроенных команд, которые выполняют фиксированную логику напрямую, встроенные skills основаны на подсказках: они дают Claude подробный план действий и позволяют ему организовать работу, используя свои инструменты. Это означает, что встроенные skills могут порождать параллельные агенты, читать файлы и адаптироваться к вашей кодовой базе. Вы вызываете встроенные skills так же, как любой другой skill: введите/ и затем имя skill. В таблице ниже <arg> указывает на обязательный аргумент, а [arg] указывает на необязательный.
| Skill | Назначение |
|---|---|
/batch <instruction> | Организуйте крупномасштабные изменения в кодовой базе параллельно. Исследует кодовую базу, разбивает работу на 5-30 независимых единиц и представляет план. После одобрения порождает один фоновый агент на единицу в изолированном git worktree. Каждый агент реализует свою единицу, запускает тесты и открывает pull request. Требует git репозиторий. Пример: /batch migrate src/ from Solid to React |
/claude-api | Загрузите справочный материал Claude API для языка вашего проекта (Python, TypeScript, Java, Go, Ruby, C#, PHP или cURL) и справочник Agent SDK для Python и TypeScript. Охватывает использование инструментов, потоковую передачу, пакеты, структурированные выходные данные и распространённые ошибки. Также активируется автоматически, когда ваш код импортирует anthropic, @anthropic-ai/sdk или claude_agent_sdk |
/debug [description] | Включите логирование отладки для текущей сессии и устраните неполадки, прочитав журнал отладки сессии. Логирование отладки отключено по умолчанию, если вы не запустили с claude --debug, поэтому запуск /debug в середине сессии начинает захватывать логи с этого момента. Опционально опишите проблему, чтобы сосредоточить анализ |
/loop [interval] <prompt> | Запустите подсказку повторно с интервалом, пока сессия остаётся открытой. Полезно для опроса развёртывания, присмотра за PR или периодического повторного запуска другого skill. Пример: /loop 5m check if the deploy finished. См. Запуск подсказок по расписанию |
/simplify [focus] | Проверьте недавно изменённые файлы на переиспользование кода, качество и проблемы эффективности, затем исправьте их. Порождает трёх агентов проверки параллельно, агрегирует их выводы и применяет исправления. Передайте текст, чтобы сосредоточиться на конкретных проблемах: /simplify focus on memory efficiency |
Начало работы
Создайте свой первый skill
Этот пример создаёт skill, который учит Claude объяснять код, используя визуальные диаграммы и аналогии. Поскольку он использует frontmatter по умолчанию, Claude может загружать его автоматически, когда вы спрашиваете, как что-то работает, или вы можете вызвать его напрямую с помощью/explain-code.
Создайте каталог skill
Создайте каталог для skill в папке личных skills. Личные skills доступны во всех ваших проектах.
Напишите SKILL.md
Каждому skill нужен файл
SKILL.md с двумя частями: YAML frontmatter (между маркерами ---), который говорит Claude, когда использовать skill, и содержимое markdown с инструкциями, которые Claude следует при вызове skill. Поле name становится /slash-command, а description помогает Claude решить, когда загружать его автоматически.Создайте ~/.claude/skills/explain-code/SKILL.md:Где находятся skills
Место, где вы сохраняете skill, определяет, кто может его использовать:| Местоположение | Путь | Применяется к |
|---|---|---|
| Enterprise | См. управляемые параметры | Все пользователи в вашей организации |
| Personal | ~/.claude/skills/<skill-name>/SKILL.md | Все ваши проекты |
| Project | .claude/skills/<skill-name>/SKILL.md | Только этот проект |
| Plugin | <plugin>/skills/<skill-name>/SKILL.md | Где включен плагин |
plugin-name:skill-name, поэтому они не могут конфликтовать с другими уровнями. Если у вас есть файлы в .claude/commands/, они работают так же, но если skill и команда имеют одинаковое имя, skill имеет приоритет.
Автоматическое обнаружение из вложенных каталогов
Когда вы работаете с файлами в подкаталогах, Claude Code автоматически обнаруживает skills из вложенных каталогов.claude/skills/. Например, если вы редактируете файл в packages/frontend/, Claude Code также ищет skills в packages/frontend/.claude/skills/. Это поддерживает настройки monorepo, где пакеты имеют свои собственные skills.
Каждый skill — это каталог с SKILL.md в качестве точки входа:
SKILL.md содержит основные инструкции и является обязательным. Другие файлы необязательны и позволяют вам создавать более мощные skills: шаблоны для заполнения Claude, примеры выходных данных, показывающие ожидаемый формат, скрипты, которые Claude может выполнять, или подробную справочную документацию. Ссылайтесь на эти файлы из вашего SKILL.md, чтобы Claude знал, что они содержат и когда их загружать. См. Добавьте вспомогательные файлы для получения дополнительной информации.
Файлы в
.claude/commands/ по-прежнему работают и поддерживают тот же frontmatter. Skills рекомендуются, так как они поддерживают дополнительные функции, такие как вспомогательные файлы.Skills из дополнительных каталогов
Skills, определённые в.claude/skills/ в каталогах, добавленных через --add-dir, загружаются автоматически и подхватываются обнаружением живых изменений, поэтому вы можете редактировать их во время сессии без перезагрузки.
Файлы CLAUDE.md из каталогов
--add-dir не загружаются по умолчанию. Чтобы загружать их, установите CLAUDE_CODE_ADDITIONAL_DIRECTORIES_CLAUDE_MD=1. См. Загрузка из дополнительных каталогов.Настройка skills
Skills настраиваются через YAML frontmatter в верхней частиSKILL.md и содержимое markdown, которое следует.
Типы содержимого skill
Файлы skill могут содержать любые инструкции, но размышление о том, как вы хотите их вызывать, помогает направить, что включить: Справочное содержимое добавляет знания, которые Claude применяет к вашей текущей работе. Соглашения, паттерны, руководства по стилю, знания предметной области. Это содержимое выполняется встроенно, поэтому Claude может использовать его вместе с контекстом вашего разговора./skill-name, а не позволять Claude решать, когда их запускать. Добавьте disable-model-invocation: true, чтобы предотвратить автоматическое срабатывание Claude.
SKILL.md может содержать что угодно, но размышление о том, как вы хотите вызывать skill (вы, Claude или оба) и где вы хотите его запускать (встроенно или в subagent), помогает направить, что включить. Для сложных skills вы также можете добавить вспомогательные файлы, чтобы сохранить основной skill сосредоточенным.
Справочник frontmatter
Помимо содержимого markdown, вы можете настроить поведение skill, используя поля YAML frontmatter между маркерами--- в верхней части вашего файла SKILL.md:
description рекомендуется, чтобы Claude знал, когда использовать skill.
| Поле | Обязательно | Описание |
|---|---|---|
name | Нет | Отображаемое имя для skill. Если опущено, использует имя каталога. Только строчные буквы, цифры и дефисы (максимум 64 символа). |
description | Рекомендуется | Что делает skill и когда его использовать. Claude использует это, чтобы решить, когда применять skill. Если опущено, использует первый абзац содержимого markdown. |
argument-hint | Нет | Подсказка, показываемая при автодополнении, чтобы указать ожидаемые аргументы. Пример: [issue-number] или [filename] [format]. |
disable-model-invocation | Нет | Установите на true, чтобы предотвратить автоматическую загрузку этого skill Claude. Используйте для рабочих процессов, которые вы хотите запустить вручную с помощью /name. По умолчанию: false. |
user-invocable | Нет | Установите на false, чтобы скрыть из меню /. Используйте для фоновых знаний, которые пользователи не должны вызывать напрямую. По умолчанию: true. |
allowed-tools | Нет | Инструменты, которые Claude может использовать без запроса разрешения, когда этот skill активен. |
model | Нет | Модель для использования, когда этот skill активен. |
effort | Нет | Уровень усилий при активном этом skill. Переопределяет уровень усилий сессии. По умолчанию: наследует из сессии. Опции: low, medium, high, max (только Opus 4.6). |
context | Нет | Установите на fork, чтобы запустить в контексте forked subagent. |
agent | Нет | Какой тип subagent использовать, когда установлен context: fork. |
hooks | Нет | Hooks, ограниченные жизненным циклом этого skill. См. Hooks в skills и agents для формата конфигурации. |
Доступные подстановки строк
Skills поддерживают подстановку строк для динамических значений в содержимом skill:| Переменная | Описание |
|---|---|
$ARGUMENTS | Все аргументы, переданные при вызове skill. Если $ARGUMENTS отсутствует в содержимом, аргументы добавляются как ARGUMENTS: <value>. |
$ARGUMENTS[N] | Доступ к конкретному аргументу по индексу на основе 0, например $ARGUMENTS[0] для первого аргумента. |
$N | Сокращение для $ARGUMENTS[N], например $0 для первого аргумента или $1 для второго. |
${CLAUDE_SESSION_ID} | Текущий ID сессии. Полезно для логирования, создания файлов, специфичных для сессии, или корреляции выходных данных skill с сессиями. |
${CLAUDE_SKILL_DIR} | Каталог, содержащий файл SKILL.md skill. Для plugin skills это подкаталог skill в плагине, а не корень плагина. Используйте это в командах bash injection для ссылки на скрипты или файлы, поставляемые с skill, независимо от текущего рабочего каталога. |
Добавьте вспомогательные файлы
Skills могут включать несколько файлов в их каталоге. Это сохраняетSKILL.md сосредоточенным на основном, позволяя Claude получать доступ к подробному справочному материалу только при необходимости. Большие справочные документы, спецификации API или коллекции примеров не нужно загружать в контекст каждый раз, когда запускается skill.
SKILL.md, чтобы Claude знал, что содержит каждый файл и когда его загружать:
Управляйте тем, кто вызывает skill
По умолчанию как вы, так и Claude можете вызывать любой skill. Вы можете ввести/skill-name, чтобы вызвать его напрямую, и Claude может загружать его автоматически при необходимости для вашего разговора. Два поля frontmatter позволяют вам ограничить это:
-
disable-model-invocation: true: Только вы можете вызвать skill. Используйте это для рабочих процессов с побочными эффектами или которые вы хотите контролировать по времени, такие как/commit,/deployили/send-slack-message. Вы не хотите, чтобы Claude решил развернуть, потому что ваш код выглядит готовым. -
user-invocable: false: Только Claude может вызвать skill. Используйте это для фоновых знаний, которые не являются действенными как команда. Skilllegacy-system-contextобъясняет, как работает старая система. Claude должен знать это при необходимости, но/legacy-system-contextне является значимым действием для пользователей.
disable-model-invocation: true предотвращает автоматическое запуск Claude:
| Frontmatter | Вы можете вызвать | Claude может вызвать | Когда загружается в контекст |
|---|---|---|---|
| (по умолчанию) | Да | Да | Описание всегда в контексте, полный skill загружается при вызове |
disable-model-invocation: true | Да | Нет | Описание не в контексте, полный skill загружается при вашем вызове |
user-invocable: false | Нет | Да | Описание всегда в контексте, полный skill загружается при вызове |
В обычной сессии описания skills загружаются в контекст, чтобы Claude знал, что доступно, но полное содержимое skill загружается только при вызове. Subagents с предварительно загруженными skills работают иначе: полное содержимое skill внедряется при запуске.
Ограничьте доступ к инструментам
Используйте полеallowed-tools, чтобы ограничить, какие инструменты Claude может использовать, когда skill активен. Этот skill создаёт режим только для чтения, где Claude может исследовать файлы, но не может их изменять:
Передайте аргументы в skills
Как вы, так и Claude можете передавать аргументы при вызове skill. Аргументы доступны через заполнитель$ARGUMENTS.
Этот skill исправляет проблему GitHub по номеру. Заполнитель $ARGUMENTS заменяется на всё, что следует за именем skill:
/fix-issue 123, Claude получает “Fix GitHub issue 123 following our coding standards…”
Если вы вызываете skill с аргументами, но skill не включает $ARGUMENTS, Claude Code добавляет ARGUMENTS: <your input> в конец содержимого skill, чтобы Claude всё ещё видел, что вы ввели.
Для доступа к отдельным аргументам по позиции используйте $ARGUMENTS[N] или более короткий $N:
/migrate-component SearchBar React Vue заменяет $ARGUMENTS[0] на SearchBar, $ARGUMENTS[1] на React и $ARGUMENTS[2] на Vue. Тот же skill, используя сокращение $N:
Продвинутые паттерны
Внедрите динамический контекст
Синтаксис!`<command>` запускает команды оболочки перед отправкой содержимого skill Claude. Выходные данные команды заменяют заполнитель, поэтому Claude получает фактические данные, а не саму команду.
Этот skill суммирует pull request, получая живые данные PR с помощью GitHub CLI. Команды !`gh pr diff` и другие запускаются первыми, и их выходные данные вставляются в подсказку:
- Каждый
!`<command>`выполняется немедленно (перед тем, как Claude что-либо увидит) - Выходные данные заменяют заполнитель в содержимом skill
- Claude получает полностью отрендеренную подсказку с фактическими данными PR
Запустите skills в subagent
Добавьтеcontext: fork в ваш frontmatter, когда вы хотите, чтобы skill запускался в изоляции. Содержимое skill становится подсказкой, которая управляет subagent. Он не будет иметь доступ к истории вашего разговора.
Skills и subagents работают вместе в двух направлениях:
| Подход | Системная подсказка | Задача | Также загружает |
|---|---|---|---|
Skill с context: fork | От типа агента (Explore, Plan и т.д.) | Содержимое SKILL.md | CLAUDE.md |
Subagent с полем skills | Тело markdown subagent | Сообщение делегирования Claude | Предварительно загруженные skills + CLAUDE.md |
context: fork вы пишете задачу в своём skill и выбираете тип агента для её выполнения. Для обратного (определение пользовательского subagent, который использует skills как справочный материал), см. Subagents.
Пример: Research skill, используя Explore agent
Этот skill запускает исследование в forked Explore agent. Содержимое skill становится задачей, и агент предоставляет инструменты только для чтения, оптимизированные для исследования кодовой базы:- Создаётся новый изолированный контекст
- Subagent получает содержимое skill в качестве своей подсказки (“Research $ARGUMENTS thoroughly…”)
- Поле
agentопределяет среду выполнения (модель, инструменты и разрешения) - Результаты суммируются и возвращаются в ваш основной разговор
agent указывает, какую конфигурацию subagent использовать. Опции включают встроенные агенты (Explore, Plan, general-purpose) или любой пользовательский subagent из .claude/agents/. Если опущено, использует general-purpose.
Ограничьте доступ Claude к skills
По умолчанию Claude может вызывать любой skill, у которого не установленdisable-model-invocation: true. Skills, которые определяют allowed-tools, предоставляют Claude доступ к этим инструментам без одобрения за использование, когда skill активен. Ваши параметры разрешений по-прежнему управляют поведением одобрения базовой линии для всех остальных инструментов. Встроенные команды, такие как /compact и /init, недоступны через инструмент Skill.
Три способа управления, какие skills может вызывать Claude:
Отключите все skills, отказав в инструменте Skill в /permissions:
Skill(name) для точного совпадения, Skill(name *) для совпадения префикса с любыми аргументами.
Скройте отдельные skills, добавив disable-model-invocation: true в их frontmatter. Это полностью удаляет skill из контекста Claude.
Поле
user-invocable управляет только видимостью меню, а не доступом инструмента Skill. Используйте disable-model-invocation: true, чтобы заблокировать программный вызов.Делитесь skills
Skills могут распространяться на разных уровнях в зависимости от вашей аудитории:- Project skills: Зафиксируйте
.claude/skills/в контроле версий - Plugins: Создайте каталог
skills/в вашем плагине - Managed: Развёртывайте организацию-широко через управляемые параметры
Генерируйте визуальный выходной сигнал
Skills могут объединять и запускать скрипты на любом языке, давая Claude возможности, выходящие за рамки того, что возможно в одной подсказке. Один мощный паттерн — генерирование визуального выходного сигнала: интерактивные HTML файлы, которые открываются в вашем браузере для исследования данных, отладки или создания отчётов. Этот пример создаёт обозреватель кодовой базы: интерактивное древовидное представление, где вы можете развёртывать и свёртывать каталоги, видеть размеры файлов с первого взгляда и определять типы файлов по цвету. Создайте каталог Skill:~/.claude/skills/codebase-visualizer/SKILL.md. Описание говорит Claude, когда активировать этот Skill, а инструкции говорят Claude запустить поставляемый скрипт:
~/.claude/skills/codebase-visualizer/scripts/visualize.py. Этот скрипт сканирует дерево каталогов и генерирует самодостаточный HTML файл с:
- Боковой панелью сводки, показывающей количество файлов, количество каталогов, общий размер и количество типов файлов
- Столбчатой диаграммой, разбивающей кодовую базу по типу файла (топ 8 по размеру)
- Свёртываемым деревом, где вы можете развёртывать и свёртывать каталоги, с цветовыми индикаторами типов файлов
codebase-map.html и открывает его в вашем браузере.
Этот паттерн работает для любого визуального выходного сигнала: графики зависимостей, отчёты о покрытии тестами, документация API или визуализации схемы базы данных. Поставляемый скрипт выполняет тяжёлую работу, пока Claude обрабатывает оркестрацию.
Устранение неполадок
Skill не срабатывает
Если Claude не использует ваш skill при необходимости:- Проверьте, что описание включает ключевые слова, которые пользователи естественно скажут
- Убедитесь, что skill появляется в
What skills are available? - Попробуйте переформулировать ваш запрос, чтобы лучше соответствовать описанию
- Вызовите его напрямую с помощью
/skill-name, если skill может быть вызван пользователем
Skill срабатывает слишком часто
Если Claude использует ваш skill, когда вы этого не хотите:- Сделайте описание более конкретным
- Добавьте
disable-model-invocation: true, если вы хотите только ручной вызов
Claude не видит все мои skills
Описания skills загружаются в контекст, чтобы Claude знал, что доступно. Если у вас много skills, они могут превысить бюджет символов. Бюджет масштабируется динамически на 2% контекстного окна, с резервным значением 16 000 символов. Запустите/context, чтобы проверить предупреждение об исключённых skills.
Чтобы переопределить лимит, установите переменную окружения SLASH_COMMAND_TOOL_CHAR_BUDGET.
Связанные ресурсы
- Subagents: делегируйте задачи специализированным агентам
- Plugins: упакуйте и распространяйте skills с другими расширениями
- Hooks: автоматизируйте рабочие процессы вокруг событий инструментов
- Memory: управляйте файлами CLAUDE.md для постоянного контекста
- Built-in commands: справочник для встроенных команд
/ - Permissions: управляйте доступом к инструментам и skills