跳轉到主要內容
Agent SDK 建立在與 Claude Code 相同的基礎上,這意味著您的 SDK 代理可以存取相同的基於檔案系統的功能:專案指令(CLAUDE.md 和規則)、skills、hooks 等。 當您省略 settingSources 時,query() 會讀取與 Claude Code CLI 相同的檔案系統設定:使用者、專案和本機設定、CLAUDE.md 檔案以及 .claude/ skills、代理和命令。若要在沒有這些的情況下執行,請傳遞 settingSources: [],這會將代理限制為您以程式設計方式設定的內容。無論此選項如何,都會讀取受管原則設定和全域 ~/.claude.json 設定。請參閱 settingSources 不控制的內容 如需每項功能的概念概述及何時使用,請參閱 擴展 Claude Code

使用 settingSources 控制檔案系統設定

設定來源選項(Python 中的 setting_sources、TypeScript 中的 settingSources)控制 SDK 載入哪些基於檔案系統的設定。傳遞明確清單以選擇加入特定來源,或傳遞空陣列以停用使用者、專案和本機設定。 此範例透過將 settingSources 設定為 ["user", "project"] 來載入使用者層級和專案層級設定:
from claude_agent_sdk import query, ClaudeAgentOptions, AssistantMessage, ResultMessage

async for message in query(
    prompt="Help me refactor the auth module",
    options=ClaudeAgentOptions(
        # "user" loads from ~/.claude/, "project" loads from ./.claude/ in cwd.
        # Together they give the agent access to CLAUDE.md, skills, hooks, and
        # permissions from both locations.
        setting_sources=["user", "project"],
        allowed_tools=["Read", "Edit", "Bash"],
    ),
):
    if isinstance(message, AssistantMessage):
        for block in message.content:
            if hasattr(block, "text"):
                print(block.text)
    if isinstance(message, ResultMessage) and message.subtype == "success":
        print(f"\nResult: {message.result}")
每個來源都會從特定位置載入設定,其中 <cwd> 是您透過 cwd 選項傳遞的工作目錄,或如果未設定則為程序的目前目錄。如需完整的型別定義,請參閱 SettingSource(TypeScript)或 SettingSource(Python)。
來源載入的內容位置
"project"專案 CLAUDE.md、.claude/rules/*.md、專案 skills、專案 hooks、專案 settings.json<cwd>/.claude/ 用於 settings.json 和 hooks;<cwd> 和每個父目錄用於 CLAUDE.md 和 rules;<cwd> 和每個父目錄直到儲存庫根目錄用於 skills
"user"使用者 CLAUDE.md、~/.claude/rules/*.md、使用者 skills、使用者設定~/.claude/
"local"CLAUDE.local.md、.claude/settings.local.json<cwd>/.claude/ 用於 settings.local.json<cwd> 和每個父目錄用於 CLAUDE.local.md
省略 settingSources 等同於 ["user", "project", "local"] cwd 選項決定 SDK 在何處尋找專案層級輸入。CLAUDE.md 和 rules 從 <cwd> 和每個父目錄載入。Skills 從 <cwd> 和每個父目錄直到儲存庫根目錄載入。專案 settings.json 和 hooks 僅從 <cwd>/.claude/ 載入,沒有父目錄回退。

settingSources 不控制的內容

settingSources 涵蓋使用者、專案和本機設定。無論其值如何,都會讀取一些輸入:
輸入行為停用方式
受管原則設定主機上存在時始終載入移除受管設定檔
~/.claude.json 全域設定始終讀取env 中使用 CLAUDE_CONFIG_DIR 重新定位
~/.claude/projects/<project>/memory/ 的自動記憶體預設載入到系統提示中在設定中設定 autoMemoryEnabled: false,或在 env 中設定 CLAUDE_CODE_DISABLE_AUTO_MEMORY=1
claude.ai MCP 連接器當作用中驗證方法是 claude.ai 訂閱時載入。傳遞 mcpServers: {} 不會抑制它們設定 strictMcpConfig: true,或在 env 中設定 ENABLE_CLAUDEAI_MCP_SERVERS=false
不要依賴預設 query() 選項進行多租戶隔離。因為上述輸入無論 settingSources 如何都會被讀取,SDK 程序可能會拾取主機層級設定和每個目錄的記憶體。對於多租戶部署,在其自己的檔案系統中執行每個租戶,並設定 settingSources: [] 加上在 env 中設定 CLAUDE_CODE_DISABLE_AUTO_MEMORY=1。請參閱 安全部署

專案指令(CLAUDE.md 和規則)

CLAUDE.md 檔案和 .claude/rules/*.md 檔案為您的代理提供有關您的專案的持久上下文:編碼慣例、建置命令、架構決策和指令。當 settingSources 包含 "project"(如上面的範例所示)時,SDK 在工作階段開始時將這些檔案載入到上下文中。代理隨後會遵循您的專案慣例,而無需在每個提示中重複它們。

CLAUDE.md 載入位置

層級位置何時載入
專案(根目錄)<cwd>/CLAUDE.md<cwd>/.claude/CLAUDE.mdsettingSources 包含 "project"
專案規則<cwd>/.claude/rules/*.md.claude/rules/*.md 在每個父目錄中settingSources 包含 "project"
專案(父目錄)cwd 上方目錄中的 CLAUDE.md 檔案settingSources 包含 "project",在工作階段開始時載入
專案(子目錄)cwd 子目錄中的 CLAUDE.md 檔案settingSources 包含 "project",當代理讀取該子樹中的檔案時按需載入
本機<cwd>/CLAUDE.local.mdCLAUDE.local.md 在每個父目錄中settingSources 包含 "local"
使用者~/.claude/CLAUDE.mdsettingSources 包含 "user"
使用者規則~/.claude/rules/*.mdsettingSources 包含 "user"
所有層級都是累加的:如果專案和使用者 CLAUDE.md 檔案都存在,代理會看到兩者。層級之間沒有硬性優先順序規則;如果指令衝突,結果取決於 Claude 如何解釋它們。編寫不衝突的規則,或在更具體的檔案中明確說明優先順序(「這些專案指令會覆蓋任何衝突的使用者層級預設值」)。
您也可以透過 systemPrompt 直接注入上下文,而無需使用 CLAUDE.md 檔案。請參閱 修改系統提示。當您想要在互動式 Claude Code 工作階段和 SDK 代理之間共享相同上下文時,請使用 CLAUDE.md。
如需如何結構化和組織 CLAUDE.md 內容的資訊,請參閱 管理 Claude 的記憶體

Skills

Skills 是 markdown 檔案,為您的代理提供專門知識和可呼叫的工作流程。與 CLAUDE.md(每個工作階段都載入)不同,skills 按需載入。代理在啟動時接收 skill 描述,並在相關時載入完整內容。 Skills 透過 settingSources 從檔案系統中發現。當 query() 上的 skills 選項被省略時,已發現的使用者和專案 skills 會被啟用,且 Skill 工具可用,符合 CLI 行為。若要控制啟用哪些 skills,請將 skills 傳遞為 "all"、skill 名稱清單或 [] 以停用全部。當 skills 被設定時,SDK 會自動將 Skill 工具新增至 allowedTools。如果您也傳遞明確的 tools 清單,請在該清單中包含 "Skill",以便 Claude 可以呼叫 skills。
from claude_agent_sdk import query, ClaudeAgentOptions, ResultMessage

# Skills in .claude/skills/ are discovered automatically
# when settingSources includes "project"
async for message in query(
    prompt="Review this PR using our code review checklist",
    options=ClaudeAgentOptions(
        setting_sources=["user", "project"],
        skills="all",
        allowed_tools=["Read", "Grep", "Glob"],
    ),
):
    if isinstance(message, ResultMessage) and message.subtype == "success":
        print(message.result)
Skills 必須建立為檔案系統成品(.claude/skills/<name>/SKILL.md)。SDK 沒有用於註冊 skills 的程式設計 API。請參閱 SDK 中的代理 Skills 以取得完整詳細資訊。
如需建立和使用 skills 的詳細資訊,請參閱 SDK 中的代理 Skills

Hooks

SDK 支援兩種定義 hooks 的方式,它們並行執行:
  • 檔案系統 hooks:settings.json 中定義的 shell 命令,當 settingSources 包含相關來源時載入。這些是您為 互動式 Claude Code 工作階段 設定的相同 hooks。
  • 程式設計 hooks: 直接傳遞給 query() 的回呼函式。這些在您的應用程式程序中執行,可以返回結構化決策。請參閱 使用 hooks 控制執行
兩種類型都在相同的 hook 生命週期中執行。如果您已經在專案的 .claude/settings.json 中有 hooks,並且您設定 settingSources: ["project"],那些 hooks 會在 SDK 中自動執行,無需額外設定。 Hook 回呼接收工具輸入並返回決策字典。返回 {} 表示允許工具繼續。若要阻止執行,請返回一個 hookSpecificOutput 物件,其中包含 permissionDecision: "deny"permissionDecisionReason。原因會作為工具結果發送給 Claude。頂層的 decisionreason 欄位已針對 PreToolUse 棄用。請參閱 hooks 指南 以取得完整的回呼簽名和返回型別。
from claude_agent_sdk import query, ClaudeAgentOptions, HookMatcher, ResultMessage


# PreToolUse hook callback. Positional args:
#   input_data: HookInput dict with tool_name, tool_input, hook_event_name
#   tool_use_id: str | None, the ID of the tool call being intercepted
#   context: HookContext, carries session metadata
async def audit_bash(input_data, tool_use_id, context):
    command = input_data.get("tool_input", {}).get("command", "")
    if "rm -rf" in command:
        return {
            "hookSpecificOutput": {
                "hookEventName": "PreToolUse",
                "permissionDecision": "deny",
                "permissionDecisionReason": "Destructive command blocked",
            }
        }
    return {}  # Empty dict: allow the tool to proceed


# Filesystem hooks from .claude/settings.json run automatically
# when settingSources loads them. You can also add programmatic hooks:
async for message in query(
    prompt="Refactor the auth module",
    options=ClaudeAgentOptions(
        setting_sources=["project"],  # Loads hooks from .claude/settings.json
        hooks={
            "PreToolUse": [
                HookMatcher(matcher="Bash", hooks=[audit_bash]),
            ]
        },
    ),
):
    if isinstance(message, ResultMessage) and message.subtype == "success":
        print(message.result)

何時使用哪種 hook 類型

Hook 類型最適合
檔案系統settings.json在 CLI 和 SDK 工作階段之間共享 hooks。支援 "command"(shell 指令碼)、"http"(POST 到端點)、"mcp_tool"(呼叫連接的 MCP 伺服器的工具)、"prompt"(LLM 評估提示)和 "agent"(生成驗證器代理)。這些在主代理和它生成的任何子代理中執行。
程式設計query() 中的回呼)應用程式特定邏輯、結構化決策和進程內整合。這些也在子代理內執行。回呼接收 agent_idagent_type 以進行區分。
TypeScript SDK 支援超出 Python 的其他 hook 事件,包括 SessionStartSessionEndTeammateIdleTaskCompleted。請參閱 hooks 指南 以取得完整的事件相容性表。
如需程式設計 hooks 的完整詳細資訊,請參閱 使用 hooks 控制執行。如需檔案系統 hook 語法,請參閱 Hooks

選擇正確的功能

Agent SDK 為您提供了多種方式來擴展代理的行為。如果您不確定要使用哪一種,此表將常見目標對應到正確的方法。
您想要…使用SDK 表面
設定代理始終遵循的專案慣例CLAUDE.mdsettingSources: ["project"] 會自動載入它
為代理提供它在相關時載入的參考資料SkillssettingSources + skills 選項
執行可重複使用的工作流程(部署、審查、發佈)使用者可呼叫的 skillssettingSources + skills 選項
將隔離的子任務委派給新的上下文(研究、審查)子代理agents 參數 + allowedTools: ["Agent"]
協調多個 Claude Code 實例,具有共享任務清單和直接的代理間訊息傳遞代理團隊不直接透過 SDK 選項設定。代理團隊是一個 CLI 功能,其中一個工作階段充當團隊主管,協調獨立隊友之間的工作
在工具呼叫上執行確定性邏輯(審計、阻止、轉換)Hookshooks 參數與回呼,或透過 settingSources 載入的 shell 指令碼
為 Claude 提供對外部服務的結構化工具存取MCPmcpServers 參數
子代理與代理團隊: 子代理是短暫的和隔離的:新的對話、一個任務、摘要返回給父代理。代理團隊協調多個獨立的 Claude Code 實例,這些實例共享任務清單並直接相互訊息傳遞。代理團隊是一個 CLI 功能。請參閱 子代理繼承的內容代理團隊比較 以取得詳細資訊。
您啟用的每項功能都會增加代理的上下文視窗。如需每項功能的成本以及這些功能如何分層組合,請參閱 擴展 Claude Code

相關資源

  • 擴展 Claude Code:所有擴展功能的概念概述,包含比較表和上下文成本分析
  • SDK 中的 Skills:以程式設計方式使用 skills 的完整指南
  • 子代理:為隔離的子任務定義和呼叫子代理
  • Hooks:在關鍵執行點攔截和控制代理行為
  • 權限:使用模式、規則和回呼控制工具存取
  • 系統提示:在不使用 CLAUDE.md 檔案的情況下注入上下文