Claude Codeは、AIによるコーディング支援を強力に推進するツールとして注目されていますが、その真価を引き出すには「Skills」の活用が欠かせません。日々の開発で繰り返す作業や、特定のドメイン知識をClaudeに効率的に教え込むことで、開発ワークフローは大きく改善するでしょう。しかし、ただ闇雲にSkillsを作成しても、かえって混乱を招いたり、期待した効果が得られなかったりする場面も出てきます。(出典: anthropic.com)
この記事では、Claude Codeを初めて触る個人開発者から、業務でAIコーディングを試したい初級〜中級エンジニア、そしてAI開発環境を整えたい小さなチームまでを対象に、Skillsを効果的に設計し、運用するための具体的なSKILL.mdの書き方と配置戦略を深掘りします。読者の皆さんが、目的、入力、手順、完了条件が明確なSkills設計メモとSKILL.mdの雛形を作成できるよう、実践的なヒントを提供します。(出典: Anthropic)
Claude CodeのSkillsはなぜ必要か?CLAUDE.mdとの役割分担

Claude Codeにおける「Skills」は、特定のタスクやワークフローをClaudeに学習させるための命令群です。これは単なるプロンプトの再利用以上の意味を持ちます。Claude Codeは、.claude/skillsディレクトリに配置されたSKILL.mdに書かれた指示を、関連するタスクが発生した際に自動的に読み込み、実行できる仕組みです。(出典: Claude Code)
では、どのような時にSkillsとして切り出すべきでしょうか。最も明確な判断基準は、「同じ指示や手順、チェックリストを何度もClaudeに貼り付けている」と感じた時です。また、CLAUDE.mdファイルが肥大化し、特定の作業手順がプロジェクトのコンテキスト記述よりも多くなってきた場合も、その部分をSkillsとして分離する良い機会と見られます。(出典: medium.com)
CLAUDE.mdはプロジェクト全体のコンテキスト、つまり技術スタック、コーディング規約、開発環境など、常にClaudeに知っておいてほしい情報を提供する役割を担います。一方、Skillsは特定のタスクに特化した「再利用可能な能力」であり、必要に応じてオンデマンドでロードされるのが特徴です。この役割分担を意識することで、Claudeのコンテキストウィンドウを効率的に使い、パフォーマンスの低下を防ぐことにも繋がります。(出典: medium.com)
想定ケース: Claude Codeを初めてチームのリポジトリへ入れる場面を想定します。読者が持ち帰る成果物は、CLAUDE.md、.claude/skills、.mcp.json、hooksの置き場所を決める小さな設計メモです。(出典: reddit.com)
使う判断: 繰り返す手順の整理、設定ファイルの下書き、差分の説明はClaude Codeに任せやすい作業です。
止める判断: 秘密情報、広い外部権限、破壊的なhooks、未確認のMCP接続は、人間が差分とログを見てから進めます。
| 置き場所 | 入れる内容 | 人間の確認 |
|---|---|---|
| CLAUDE.md | 共通ルール | 長すぎないか |
| .claude/skills | 繰り返す手順 | 実行条件が明確か |
| .mcp.json | 外部接続 | 権限が最小か |
SKILL.mdの基本構造と効果的な設計原則

Claude CodeのSkillsは、特定のディレクトリ構造に従って配置されます。基本的な構造は、.claude/skillsディレクトリの下に、スキル名を冠したディレクトリを作成し、その中にSKILL.mdファイルを置く形です。(出典: Connect Claude Code to tools via MCP)
.claude/
├── skills/
│ ├── my-first-skill/
│ │ └── SKILL.md
│ └── code-review-skill/
│ └── SKILL.md
└── CLAUDE.md
SKILL.mdファイルは、大きく分けて「YAMLフロントマター」と「Markdown本文」の2つの部分で構成されます。
人間がMCPとSkillsの範囲を決める
↓
Claude Codeに対象ファイルと制約を渡す
↓
Claude Codeが差分と実行ログを作る
↓
人間が権限、秘密情報、戻し方を確認する
↓
問題なければ反映する
実践!SKILL.mdテンプレートと依頼例

ここでは、前述の設計原則を踏まえたSKILL.mdの推奨テンプレートと、具体的な依頼例を見ていきましょう。
--- name: my-skill-name description: このスキルは何をするのか、いつ使うべきかを簡潔に記述します。 disable-model-invocation: false # Claudeによる自動起動を許可するかどうか (trueで無効化) ---\n # スキル名
## 目的
このスキルが達成する具体的な目標を記述します。
## 役割
このスキルを実行する際のClaudeの役割(例: 「あなたは厳格なコードレビューアです」)を記述します。
## 入力
Claudeがこのスキルを実行するために必要な入力情報を記述します。例:
* レビュー対象のファイルパス
* 変更の目的
## 手順
Claudeが実行すべきステップバイステップの指示を記述します。箇条書きや番号付きリストを使うと分かりやすいです。
1. [入力]で指定されたファイルの内容を読み込みます。
2. [制約]に従って分析を行います。
## 制約
このスキルを実行する上で守るべきルールや考慮事項を記述します。例:
* 既存のコードスタイルを尊重すること。
* 特定のライブラリやフレームワークのベストプラクティスに従うこと。
## 出力形式
Claudeが生成する結果の形式を具体的に記述します。例:
* Markdown形式の箇条書き
* JSON形式のデータ構造
## 例
具体的な入力と期待される出力の例を記述すると、Claudeの理解が深まります。
### 例1: シンプルなコードレビュー
入力:
## レビュー観点

-
コードスタイル: プロジェクトの既存スタイル(インデント、命名規則など)との整合性。
-
バグの可能性: エッジケース、NULLポインタ、オフバイワンエラーなどの潜在的なバグ。
-
可読性: コードが意図を明確に伝えているか、コメントは適切か。
Claude Codeへの依頼例
依頼例1:
対象ファイル: CLAUDE.md と .claude/skills/release-check/SKILL.md
変更範囲: 共通ルールをCLAUDE.mdに残し、繰り返す確認手順をSkillへ分ける
制約: APIキー、接続文字列、社内URLの実値は書かない
確認観点: CLAUDE.mdが短く保たれ、SKILL.mdだけで実行手順が分かるか
依頼例2:
対象ファイル: .mcp.json と .claude/settings.json
変更範囲: 外部ツール接続の責務と権限範囲を整理する
制約: トークンはプレースホルダーにし、読み取り権限から始める
確認観点: MCPが必要な作業、不要な作業、人間の承認が必要な作業が分かれているか
AI任せにしない:人間が確認すべきポイントとよくある落とし穴
Skillsを活用して作業を自動化しても、人間による最終確認は不可欠です。Claude Codeは強力なツールですが、常に完璧な結果を出すわけではありません。特に、以下のような点には注意を払いましょう。(出典: Best practices for Claude Code)
人間が確認するリスト
- 変更差分の確認: Claudeが意図した変更範囲を正しく理解しているか、出力された内容が本当に差分に基づいているかを確認します。特に、
git diffのような外部コマンドの出力が正しく解釈されているかは重要です。
自分だけのSkillsを育て、チームで活用する次の一歩
Claude CodeのSkillsは、一度作ったら終わりではありません。日々の開発で新たな定型作業を見つけたり、既存のSkillsの改善点を発見したりする中で、継続的に育てていくものです。正直なところ、完璧なSkillsを一発で作り上げるのは難しいものだと感じます。まずは、自分が毎日行っている小さな繰り返し作業を一つ選び、それをSkillsとして切り出すことから始めてみましょう。
例えば、コミットメッセージの整形、特定のログ解析、簡単な設定ファイルの生成など、どんなに小さなタスクでも構いません。実際に作ってみることで、SKILL.mdの書き方や、Claudeとの対話のコツが掴めてくるはずです。そして、そのSkillsが本当に役立つものになったら、チーム内で共有することも検討してみてください。チーム全体の生産性向上に繋がる可能性を秘めているのは間違いありません。
次にSkillsを改善する際には、Claude Codeの公式ドキュメントや、GitHubのコミュニティで共有されている事例も参考にすると良いでしょう。他の開発者がどのようにSkillsを活用しているかを知ることで、新たな発見やアイデアが生まれるかもしれません。急いで飛びつくよりも、まずは小さな成功体験を積み重ねていくのが、Skillsを使いこなす上で現実的なアプローチだと見ています。
参考文献
anthropic.com Anthropic Claude Code medium.com medium.com reddit.com Connect Claude Code to tools via MCP Best practices for Claude Code
