メインコンテンツへスキップ

Documentation Index

Fetch the complete documentation index at: https://code.claude.com/docs/llms.txt

Use this file to discover all available pages before exploring further.

Agent SDK は、Claude Code を支える同じツール、エージェントループ、およびコンテキスト管理を提供します。スクリプトと CI/CD 用の CLI として、または完全なプログラムによる制御のための Python および TypeScript パッケージとして利用できます。
CLI は以前「headless mode」と呼ばれていました。-p フラグとすべての CLI オプションは同じように機能します。
CLI からプログラムで Claude Code を実行するには、プロンプトと任意の CLI オプション を指定して -p を渡します。
claude -p "Find and fix the bug in auth.py" --allowedTools "Read,Edit,Bash"
このページでは、CLI(claude -p)経由で Agent SDK を使用することについて説明しています。構造化された出力、ツール承認コールバック、およびネイティブメッセージオブジェクトを備えた Python および TypeScript SDK パッケージについては、完全な Agent SDK ドキュメント を参照してください。

基本的な使用方法

任意の claude コマンドに -p(または --print)フラグを追加して、非対話的に実行します。すべての CLI オプション-p で機能します。以下を含みます。 この例は、コードベースについて Claude に質問し、応答を出力します。
claude -p "What does the auth module do?"

ベアモードでより高速に開始する

--bare を追加して、hooks、skills、plugins、MCP サーバー、auto memory、および CLAUDE.md の自動検出をスキップすることで、起動時間を短縮します。これがない場合、claude -p は対話型セッションと同じ コンテキスト を読み込みます。これには、作業ディレクトリまたは ~/.claude で設定されたすべてのものが含まれます。 ベアモードは、すべてのマシンで同じ結果が必要な CI とスクリプトに役立ちます。チームメイトの ~/.claude のフック、またはプロジェクトの .mcp.json の MCP サーバーは実行されません。ベアモードはそれらを読み込まないためです。明示的に渡すフラグのみが有効になります。 この例は、ベアモードで 1 回限りの要約タスクを実行し、Read ツールを事前承認して、呼び出しが許可プロンプトなしで完了するようにします。
claude --bare -p "Summarize this file" --allowedTools "Read"
ベアモードでは、Claude は Bash、ファイル読み取り、およびファイル編集ツールにアクセスできます。フラグを使用して必要なコンテキストを渡します。
読み込むもの使用するもの
システムプロンプト追加--append-system-prompt--append-system-prompt-file
設定--settings <file-or-json>
MCP サーバー--mcp-config <file-or-json>
カスタムエージェント--agents <json>
プラグインディレクトリ--plugin-dir <path>
ベアモードは OAuth とキーチェーン読み取りをスキップします。Anthropic 認証は ANTHROPIC_API_KEY または --settings に渡される JSON の apiKeyHelper から取得する必要があります。Bedrock、Vertex、および Foundry は通常のプロバイダー認証情報を使用します。
--bare はスクリプトおよび SDK 呼び出しの推奨モードであり、将来のリリースで -p のデフォルトになります。

これらの例は、一般的な CLI パターンを強調しています。CI およびその他のスクリプト呼び出しの場合は、--bare を追加して、ローカルで設定されているものを取得しないようにします。

構造化された出力を取得する

--output-format を使用して、応答がどのように返されるかを制御します。
  • text(デフォルト):プレーンテキスト出力
  • json:結果、セッション ID、およびメタデータを含む構造化 JSON
  • stream-json:リアルタイムストリーミング用の改行区切り JSON
この例は、セッションメタデータを含む JSON としてプロジェクト概要を返し、テキスト結果は result フィールドに含まれます。
claude -p "Summarize this project" --output-format json
特定のスキーマに準拠した出力を取得するには、--output-format json--json-schema および JSON Schema 定義と共に使用します。応答には、リクエストに関するメタデータ(セッション ID、使用状況など)が含まれ、構造化された出力は structured_output フィールドに含まれます。 この例は、auth.py から関数名を抽出し、文字列の配列として返します。
claude -p "Extract the main function names from auth.py" \
  --output-format json \
  --json-schema '{"type":"object","properties":{"functions":{"type":"array","items":{"type":"string"}}},"required":["functions"]}'
jq などのツールを使用して応答を解析し、特定のフィールドを抽出します。
# テキスト結果を抽出
claude -p "Summarize this project" --output-format json | jq -r '.result'

# 構造化された出力を抽出
claude -p "Extract function names from auth.py" \
  --output-format json \
  --json-schema '{"type":"object","properties":{"functions":{"type":"array","items":{"type":"string"}}},"required":["functions"]}' \
  | jq '.structured_output'

レスポンスをストリーミングする

--output-format stream-json--verbose および --include-partial-messages と共に使用して、生成されるトークンをリアルタイムで受け取ります。各行はイベントを表す JSON オブジェクトです。
claude -p "Explain recursion" --output-format stream-json --verbose --include-partial-messages
次の例は、jq を使用してテキストデルタをフィルタリングし、ストリーミングテキストのみを表示します。-r フラグは生の文字列を出力し(引用符なし)、-j は改行なしで結合するため、トークンは継続的にストリーミングされます。
claude -p "Write a poem" --output-format stream-json --verbose --include-partial-messages | \
  jq -rj 'select(.type == "stream_event" and .event.delta.type? == "text_delta") | .event.delta.text'
API リクエストが再試行可能なエラーで失敗すると、Claude Code は再試行前に system/api_retry イベントを発行します。これを使用して、再試行の進行状況を表示したり、カスタムバックオフロジックを実装したりできます。
フィールド説明
type"system"メッセージタイプ
subtype"api_retry"これが再試行イベントであることを識別します
attempt整数現在の試行番号(1 から開始)
max_retries整数許可される再試行の合計
retry_delay_ms整数次の試行までのミリ秒
error_status整数または nullHTTP ステータスコード、または HTTP レスポンスのない接続エラーの場合は null
error文字列エラーカテゴリ:authentication_failedoauth_org_not_allowedbilling_errorrate_limitinvalid_requestserver_errormax_output_tokens、または unknown
uuid文字列一意のイベント識別子
session_id文字列イベントが属するセッション
system/init イベントは、モデル、ツール、MCP サーバー、および読み込まれたプラグインを含むセッションメタデータを報告します。CLAUDE_CODE_SYNC_PLUGIN_INSTALL が設定されていない限り、ストリームの最初のイベントです。その場合、plugin_install イベントがそれより前にあります。プラグインフィールドを使用して、プラグインが読み込まれなかった場合に CI を失敗させます。
フィールド説明
plugins配列正常に読み込まれたプラグイン。各プラグインは namepath を持ちます
plugin_errors配列満たされていない依存関係バージョンなどのプラグイン読み込み時エラー。各エラーは plugintype、および message を持ちます。影響を受けたプラグインは降格され、plugins から削除されます。エラーがない場合、キーは省略されます
CLAUDE_CODE_SYNC_PLUGIN_INSTALL が設定されている場合、Claude Code は最初のターンの前にマーケットプレイスプラグインがインストールされている間、system/plugin_install イベントを発行します。これらを使用して、独自の UI にインストール進行状況を表示します。
フィールド説明
type"system"メッセージタイプ
subtype"plugin_install"これがプラグインインストールイベントであることを識別します
status"started""installed""failed"、または "completed"startedcompleted は全体的なインストールを囲みます。installedfailed は個別のマーケットプレイスを報告します
name文字列(オプション)マーケットプレイス名。installedfailed に存在します
error文字列(オプション)失敗メッセージ。failed に存在します
uuid文字列一意のイベント識別子
session_id文字列イベントが属するセッション
コールバックとメッセージオブジェクトを使用したプログラムによるストリーミングについては、Agent SDK ドキュメントの リアルタイムでレスポンスをストリーミングする を参照してください。

ツールを自動承認する

--allowedTools を使用して、Claude が確認を求めずに特定のツールを使用できるようにします。この例はテストスイートを実行し、失敗を修正し、Claude が許可を求めずに Bash コマンドを実行し、ファイルを読み取り/編集できるようにします。
claude -p "Run the test suite and fix any failures" \
  --allowedTools "Bash,Read,Edit"
セッション全体のベースラインを設定する代わりに個別のツールをリストするには、パーミッションモード を渡します。dontAskpermissions.allow ルールまたは 読み取り専用コマンドセット にないものをすべて拒否します。これはロックダウンされた CI 実行に役立ちます。acceptEdits を使用すると、Claude はプロンプトなしでファイルを書き込むことができ、mkdirtouchmvcp などの一般的なファイルシステムコマンドも自動承認します。その他のシェルコマンドとネットワークリクエストは、--allowedTools エントリまたは permissions.allow ルールが必要です。そうでない場合、実行が試みられると実行が中止されます。
claude -p "Apply the lint fixes" --permission-mode acceptEdits

コミットを作成する

この例は、ステージされた変更を確認し、適切なメッセージを含むコミットを作成します。
claude -p "Look at my staged changes and create an appropriate commit" \
  --allowedTools "Bash(git diff *),Bash(git log *),Bash(git status *),Bash(git commit *)"
--allowedTools フラグは パーミッションルール構文 を使用します。末尾の * はプレフィックスマッチングを有効にするため、Bash(git diff *)git diff で始まるすべてのコマンドを許可します。スペースは重要です。スペースがない場合、Bash(git diff*)git diff-index にも一致します。
ユーザーが呼び出した skills/commit など)および 組み込みコマンド は、対話モードでのみ利用可能です。-p モードでは、代わりに実行したいタスクを説明してください。

システムプロンプトをカスタマイズする

--append-system-prompt を使用して、Claude Code のデフォルト動作を保持しながら指示を追加します。この例は PR diff を Claude にパイプし、セキュリティ脆弱性をレビューするよう指示します。
gh pr diff "$1" | claude -p \
  --append-system-prompt "You are a security engineer. Review for vulnerabilities." \
  --output-format json
デフォルトプロンプトを完全に置き換える --system-prompt を含む詳細なオプションについては、システムプロンプトフラグ を参照してください。

会話を続ける

--continue を使用して最新の会話を続けるか、--resume をセッション ID と共に使用して特定の会話を続けます。この例はレビューを実行し、その後フォローアッププロンプトを送信します。
# 最初のリクエスト
claude -p "Review this codebase for performance issues"

# 最新の会話を続ける
claude -p "Now focus on the database queries" --continue
claude -p "Generate a summary of all issues found" --continue
複数の会話を実行している場合は、セッション ID をキャプチャして特定の会話を再開します。
session_id=$(claude -p "Start a review" --output-format json | jq -r '.session_id')
claude -p "Continue that review" --resume "$session_id"

次のステップ