使用 Agent SDK 构建一个 AI 代理,它可以读取你的代码、发现错误并修复它们,所有这一切都无需手动干预。 你将做什么: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 设置一个项目
- 创建一个包含一些有缺陷代码的文件
- 运行一个代理,自动查找并修复错误
前置条件
- Node.js 18+ 或 Python 3.10+
- 一个 Anthropic 账户(在此注册)
设置
安装 SDK
为你的语言安装 Agent SDK 包:
- TypeScript
- Python (uv)
- Python (pip)
TypeScript SDK 为你的平台捆绑了一个本地 Claude Code 二进制文件作为可选依赖项,所以你不需要单独安装 Claude Code。
设置你的 API 密钥
从 Claude 控制台获取 API 密钥,然后在你的项目目录中创建一个 SDK 还支持通过第三方 API 提供商进行身份验证:
.env 文件:- Amazon Bedrock:设置
CLAUDE_CODE_USE_BEDROCK=1环境变量并配置 AWS 凭证 - Claude Platform on AWS:设置
CLAUDE_CODE_USE_ANTHROPIC_AWS=1和ANTHROPIC_AWS_WORKSPACE_ID,然后配置 AWS 凭证 - Google Vertex AI:设置
CLAUDE_CODE_USE_VERTEX=1环境变量并配置 Google Cloud 凭证 - Microsoft Azure:设置
CLAUDE_CODE_USE_FOUNDRY=1环境变量并配置 Azure 凭证
除非事先获得批准,否则 Anthropic 不允许第三方开发者提供 claude.ai 登录或对其产品的速率限制,包括基于 Claude Agent SDK 构建的代理。请改用本文档中描述的 API 密钥身份验证方法。
创建一个有缺陷的文件
此快速开始将引导你构建一个可以查找和修复代码中错误的代理。首先,你需要一个包含一些有意错误的文件供代理修复。在my-agent 目录中创建 utils.py 并粘贴以下代码:
calculate_average([])会因除以零而崩溃get_user_name(None)会因 TypeError 而崩溃
构建一个查找和修复错误的代理
如果你使用 Python SDK,创建agent.py,或者如果使用 TypeScript,创建 agent.ts:
-
query:创建 agentic 循环的主入口点。它返回一个异步迭代器,所以你使用async for来流式传输 Claude 工作时的消息。查看 Python 或 TypeScript SDK 参考中的完整 API。 -
prompt:你想让 Claude 做什么。Claude 根据任务确定要使用哪些工具。 -
options:代理的配置。此示例使用allowedTools预先批准Read、Edit和Glob,以及permissionMode: "acceptEdits"来自动批准文件更改。其他选项包括systemPrompt、mcpServers等。查看 Python 或 TypeScript 的所有选项。
async for 循环在 Claude 思考、调用工具、观察结果并决定下一步做什么时继续运行。每次迭代都会产生一条消息:Claude 的推理、工具调用、工具结果或最终结果。SDK 处理编排(工具执行、上下文管理、重试),所以你只需使用流。当 Claude 完成任务或遇到错误时,循环结束。
循环内的消息处理过滤人类可读的输出。如果没有过滤,你会看到原始消息对象,包括系统初始化和内部状态,这对调试很有用,但通常很冗长。
此示例使用流式传输来实时显示进度。如果你不需要实时输出(例如,对于后台作业或 CI 管道),你可以一次性收集所有消息。有关详细信息,请参阅流式传输与单轮模式。
运行你的代理
你的代理已准备好。使用以下命令运行它:- Python
- TypeScript
utils.py。你会看到处理空列表和空用户的防御性代码。你的代理自主地:
- 读取
utils.py以理解代码 - 分析了逻辑并识别了会导致崩溃的边界情况
- 编辑了文件以添加适当的错误处理
如果你看到”API key not found”,请确保你已在
.env 文件或 shell 环境中设置了 ANTHROPIC_API_KEY 环境变量。有关更多帮助,请参阅完整故障排除指南。尝试其他提示
现在你的代理已设置好,尝试一些不同的提示:"Add docstrings to all functions in utils.py""Add type hints to all functions in utils.py""Create a README.md documenting the functions in utils.py"
自定义你的代理
你可以通过更改选项来修改代理的行为。以下是一些示例: 添加网络搜索功能:Bash 后,尝试:"Write unit tests for utils.py, run them, and fix any failures"
关键概念
工具控制你的代理可以做什么:| 工具 | 代理可以做什么 |
|---|---|
Read、Glob、Grep | 只读分析 |
Read、Edit、Glob | 分析和修改代码 |
Read、Edit、Bash、Glob、Grep | 完全自动化 |
| 模式 | 行为 | 用例 |
|---|---|---|
acceptEdits | 自动批准文件编辑和常见文件系统命令,询问其他操作 | 受信任的开发工作流 |
dontAsk | 拒绝不在 allowedTools 中的任何内容 | 锁定的无头代理 |
auto(仅 TypeScript) | 模型分类器批准或拒绝每个工具调用 | 具有安全防护的自主代理 |
bypassPermissions | 运行每个工具而不提示 | 沙箱 CI、完全受信任的环境 |
default | 需要 canUseTool 回调来处理批准 | 自定义批准流程 |
acceptEdits 模式,它自动批准文件操作,以便代理可以在没有交互式提示的情况下运行。如果你想提示用户批准,使用 default 模式并提供一个 canUseTool 回调来收集用户输入。为了获得更多控制,请参阅权限。
故障排除
API 错误 thinking.type.enabled 不支持此模型
Claude Opus 4.7 用 thinking.type.adaptive 替换了 thinking.type.enabled。当你选择 claude-opus-4-7 时,较旧的 Agent SDK 版本会失败,出现以下 API 错误: