Claude Code SDK 已重新命名為 Claude Agent SDK,其文件也已重新組織。這項變更反映了 SDK 在構建 AI 代理方面的更廣泛能力,不僅限於編碼任務。
變更內容
方面 | 舊版 | 新版 |
---|
套件名稱 (TS/JS) | @anthropic-ai/claude-code | @anthropic-ai/claude-agent-sdk |
Python 套件 | claude-code-sdk | claude-agent-sdk |
文件位置 | Claude Code 文件 → SDK 部分 | API 指南 → Agent SDK 部分 |
文件變更: Agent SDK 文件已從 Claude Code 文件移至 API 指南中的專門 Agent SDK 部分。Claude Code 文件現在專注於 CLI 工具和自動化功能。
遷移步驟
對於 TypeScript/JavaScript 專案
1. 卸載舊套件:
npm uninstall @anthropic-ai/claude-code
2. 安裝新套件:
npm install @anthropic-ai/claude-agent-sdk
3. 更新您的匯入:
將所有從 @anthropic-ai/claude-code
的匯入改為 @anthropic-ai/claude-agent-sdk
:
// 之前
import { query, tool, createSdkMcpServer } from "@anthropic-ai/claude-code";
// 之後
import {
query,
tool,
createSdkMcpServer,
} from "@anthropic-ai/claude-agent-sdk";
4. 更新 package.json 依賴項:
如果您在 package.json
中列出了該套件,請更新它:
// 之前
{
"dependencies": {
"@anthropic-ai/claude-code": "^1.0.0"
}
}
// 之後
{
"dependencies": {
"@anthropic-ai/claude-agent-sdk": "^0.1.0"
}
}
就是這樣!不需要其他程式碼變更。
對於 Python 專案
1. 卸載舊套件:
pip uninstall claude-code-sdk
2. 安裝新套件:
pip install claude-agent-sdk
3. 更新您的匯入:
將所有從 claude_code_sdk
的匯入改為 claude_agent_sdk
:
# 之前
from claude_code_sdk import query, ClaudeCodeOptions
# 之後
from claude_agent_sdk import query, ClaudeAgentOptions
4. 更新類型名稱:
將 ClaudeCodeOptions
改為 ClaudeAgentOptions
:
# 之前
from claude_agent_sdk import query, ClaudeCodeOptions
options = ClaudeCodeOptions(
model="claude-sonnet-4-5"
)
# 之後
from claude_agent_sdk import query, ClaudeAgentOptions
options = ClaudeAgentOptions(
model="claude-sonnet-4-5"
)
5. 檢視重大變更
進行完成遷移所需的任何程式碼變更。
重大變更
為了改善隔離性和明確配置,Claude Agent SDK v0.1.0 為從 Claude Code SDK 遷移的使用者引入了重大變更。在遷移前請仔細檢視此部分。
Python:ClaudeCodeOptions 重新命名為 ClaudeAgentOptions
變更內容: Python SDK 類型 ClaudeCodeOptions
已重新命名為 ClaudeAgentOptions
。
遷移:
# 之前 (v0.0.x)
from claude_agent_sdk import query, ClaudeCodeOptions
options = ClaudeCodeOptions(
model="claude-sonnet-4-5",
permission_mode="acceptEdits"
)
# 之後 (v0.1.0)
from claude_agent_sdk import query, ClaudeAgentOptions
options = ClaudeAgentOptions(
model="claude-sonnet-4-5",
permission_mode="acceptEdits"
)
變更原因: 類型名稱現在符合「Claude Agent SDK」品牌,並在 SDK 的命名慣例中提供一致性。
系統提示不再為預設
變更內容: SDK 不再預設使用 Claude Code 的系統提示。
遷移:
// 之前 (v0.0.x) - 預設使用 Claude Code 的系統提示
const result = query({ prompt: "Hello" });
// 之後 (v0.1.0) - 預設使用空的系統提示
// 要獲得舊行為,明確請求 Claude Code 的預設:
const result = query({
prompt: "Hello",
options: {
systemPrompt: { type: "preset", preset: "claude_code" }
}
});
// 或使用自訂系統提示:
const result = query({
prompt: "Hello",
options: {
systemPrompt: "You are a helpful coding assistant"
}
});
變更原因: 為 SDK 應用程式提供更好的控制和隔離。您現在可以構建具有自訂行為的代理,而不會繼承 Claude Code 的 CLI 專用指令。
設定來源不再預設載入
變更內容: SDK 不再預設從檔案系統設定(CLAUDE.md、settings.json、斜線命令等)讀取。
遷移:
// 之前 (v0.0.x) - 自動載入所有設定
const result = query({ prompt: "Hello" });
// 會從以下位置讀取:
// - ~/.claude/settings.json (使用者)
// - .claude/settings.json (專案)
// - .claude/settings.local.json (本地)
// - CLAUDE.md 檔案
// - 自訂斜線命令
// 之後 (v0.1.0) - 預設不載入設定
// 要獲得舊行為:
const result = query({
prompt: "Hello",
options: {
settingSources: ["user", "project", "local"]
}
});
// 或只載入特定來源:
const result = query({
prompt: "Hello",
options: {
settingSources: ["project"] // 只有專案設定
}
});
變更原因: 確保 SDK 應用程式具有可預測的行為,獨立於本地檔案系統配置。這對以下情況特別重要:
- CI/CD 環境 - 沒有本地自訂的一致行為
- 部署的應用程式 - 不依賴檔案系統設定
- 測試 - 隔離的測試環境
- 多租戶系統 - 防止使用者之間的設定洩漏
向後相容性: 如果您的應用程式依賴檔案系統設定(自訂斜線命令、CLAUDE.md 指令等),請在您的選項中新增 settingSources: ['user', 'project', 'local']
。
為什麼重新命名?
Claude Code SDK 最初是為編碼任務設計的,但它已發展成為構建所有類型 AI 代理的強大框架。新名稱「Claude Agent SDK」更好地反映了其能力:
- 構建商業代理(法律助理、財務顧問、客戶支援)
- 創建專門的編碼代理(SRE 機器人、安全審查員、程式碼審查代理)
- 為任何領域開發自訂代理,具有工具使用、MCP 整合等功能
獲得幫助
如果您在遷移過程中遇到任何問題:
對於 TypeScript/JavaScript:
- 檢查所有匯入都已更新為使用
@anthropic-ai/claude-agent-sdk
- 驗證您的 package.json 具有新的套件名稱
- 執行
npm install
以確保依賴項已更新
對於 Python:
- 檢查所有匯入都已更新為使用
claude_agent_sdk
- 驗證您的 requirements.txt 或 pyproject.toml 具有新的套件名稱
- 執行
pip install claude-agent-sdk
以確保套件已安裝
請參閱疑難排解指南以了解常見問題。
下一步