Was this page helpful?
本教程展示了如何使用 Agent Skills 创建 PowerPoint 演示文稿。您将学习如何启用 Skills、进行简单请求以及访问生成的文件。
预构建的 Agent Skills 通过专业知识扩展 Claude 的功能,用于创建文档、分析数据和处理文件等任务。Anthropic 在 API 中提供以下预构建的 Agent Skills:
想要创建自定义 Skills? 请参阅 Agent Skills Cookbook 以获取使用特定领域专业知识构建您自己的 Skills 的示例。
首先,检查哪些 Skills 可用。使用 Skills API 列出所有 Anthropic 管理的 Skills:
您会看到以下 Skills:pptx、xlsx、docx 和 pdf。
此 API 返回每个 Skill 的元数据:其名称和描述。Claude 在启动时加载此元数据以了解哪些 Skills 可用。这是渐进式披露的第一个级别,其中 Claude 发现 Skills 而无需加载其完整说明。
现在使用 PowerPoint Skill 创建关于可再生能源的演示文稿。使用 Messages API 中的 container 参数指定 Skills:
让我们分解每个部分的作用:
container.skills: 指定 Claude 可以使用哪些 Skillstype: "anthropic": 表示这是一个 Anthropic 管理的 Skillskill_id: "pptx": PowerPoint Skill 标识符version: "latest": Skill 版本设置为最近发布的版本tools: 启用代码执行(Skills 需要)code-execution-2025-08-25 和 skills-2025-10-02当您进行此请求时,Claude 会自动将您的任务与相关的 Skill 匹配。由于您要求演示文稿,Claude 确定 PowerPoint Skill 是相关的并加载其完整说明:渐进式披露的第二个级别。然后 Claude 执行 Skill 的代码来创建您的演示文稿。
演示文稿在代码执行容器中创建并保存为文件。响应包含带有文件 ID 的文件引用。提取文件 ID 并使用 Files API 下载它:
有关处理生成文件的完整详情,请参阅代码执行工具文档。
现在您已经使用 Skills 创建了第一个文档,请尝试这些变体:
现在您已经使用了预构建的 Agent Skills,您可以:
ant beta:skills list --source anthropicimport anthropic
client = anthropic.Anthropic()
# Create a message with the PowerPoint Skill
response = client.beta.messages.create(
model="claude-opus-4-7",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"skills": [{"type": "anthropic", "skill_id": "pptx", "version": "latest"}]
},
messages=[
{
"role": "user",
"content": "Create a presentation about renewable energy with 5 slides",
}
],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}],
)
print(response.content)from typing import Any
response: Any = None
# Extract file ID from response
file_id = None
for block in response.content:
if block.type == "tool_use" and block.name == "code_execution":
# File ID is in the tool result
for result_block in block.content:
if hasattr(result_block, "file_id"):
file_id = result_block.file_id
break
if file_id:
# Download the file
file_content = client.beta.files.download(
file_id=file_id, betas=["files-api-2025-04-14"]
)
# Save to disk
with open("renewable_energy.pptx", "wb") as f:
file_content.write_to_file(f.name)
print(f"Presentation saved to renewable_energy.pptx")response = client.beta.messages.create(
model="claude-opus-4-7",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"skills": [{"type": "anthropic", "skill_id": "xlsx", "version": "latest"}]
},
messages=[
{
"role": "user",
"content": "Create a quarterly sales tracking spreadsheet with sample data",
}
],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}],
)response = client.beta.messages.create(
model="claude-opus-4-7",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"skills": [{"type": "anthropic", "skill_id": "docx", "version": "latest"}]
},
messages=[
{
"role": "user",
"content": "Write a 2-page report on the benefits of renewable energy",
}
],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}],
)response = client.beta.messages.create(
model="claude-opus-4-7",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"skills": [{"type": "anthropic", "skill_id": "pdf", "version": "latest"}]
},
messages=[{"role": "user", "content": "Generate a PDF invoice template"}],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}],
)学习编写有效 Skills 的最佳实践