Agent Skills는 체계적으로 구성된 지침, 스크립트, 리소스 폴더를 통해 Claude의 기능을 확장합니다. 이 가이드에서는 사전 구축된 Skills와 커스텀 Skills를 Claude API와 함께 사용하는 방법을 보여줍니다.
요청/응답 스키마 및 모든 매개변수를 포함한 전체 API 레퍼런스는 다음을 참조하세요:
Agent Skills의 아키텍처와 실제 활용 사례에 대한 심층 분석은 엔지니어링 블로그를 읽어보세요: Equipping agents for the real world with Agent Skills.
Skills는 코드 실행 도구를 통해 Messages API와 통합됩니다. Anthropic이 관리하는 사전 구축된 Skills를 사용하든 직접 업로드한 커스텀 Skills를 사용하든, 통합 형태는 동일합니다—둘 다 코드 실행이 필요하며 동일한 container 구조를 사용합니다.
Skills는 출처에 관계없이 Messages API에서 동일하게 통합됩니다. container 매개변수에 skill_id, type, 그리고 선택적으로 version을 지정하면 코드 실행 환경에서 실행됩니다.
두 가지 출처의 Skills를 사용할 수 있습니다:
| 항목 | Anthropic Skills | 커스텀 Skills |
|---|---|---|
| Type 값 | anthropic | custom |
| Skill ID | 짧은 이름: pptx, xlsx, docx, pdf | 생성됨: skill_01AbCdEfGhIjKlMnOpQrStUv |
| 버전 형식 | 날짜 기반: 20251013 또는 latest | 에포크 타임스탬프: 1759178010641129 또는 latest |
| 관리 | Anthropic이 사전 구축 및 유지 관리 | Skills API를 통해 업로드 및 관리 |
| 가용성 | 모든 사용자에게 제공 | 워크스페이스 전용 |
두 Skill 출처 모두 Skills 목록 엔드포인트에서 반환됩니다(source 매개변수를 사용하여 필터링). 통합 형태와 실행 환경은 동일하며—유일한 차이점은 Skills의 출처와 관리 방식입니다.
Skills를 사용하려면 다음이 필요합니다:
code-execution-2025-08-25 - 코드 실행 활성화 (Skills에 필수)skills-2025-10-02 - Skills API 활성화files-api-2025-04-14 - 컨테이너에서 파일 업로드/다운로드용Skills는 Messages API의 container 매개변수를 사용하여 지정합니다. 요청당 최대 8개의 Skills를 포함할 수 있습니다.
구조는 Anthropic Skills와 커스텀 Skills 모두 동일합니다—필수 type과 skill_id를 지정하고, 선택적으로 version을 포함하여 특정 버전에 고정할 수 있습니다:
import anthropic
client = anthropic.Anthropic()
response = client.beta.messages.create(
model="claude-opus-4-6",
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"
}],
tools=[{
"type": "code_execution_20250825",
"name": "code_execution"
}]
)Skills가 문서(Excel, PowerPoint, PDF, Word)를 생성하면 응답에 file_id 속성을 반환합니다. 이 파일을 다운로드하려면 Files API를 사용해야 합니다.
작동 방식:
file_id가 포함됩니다예시: Excel 파일 생성 및 다운로드
import anthropic
client = anthropic.Anthropic()
# 1단계: Skill을 사용하여 파일 생성
response = client.beta.messages.create(
model="claude-opus-4-6",
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 an Excel file with a simple budget spreadsheet"
}],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}]
)
# 2단계: 응답에서 파일 ID 추출
def extract_file_ids(response):
file_ids = []
for item in response.content:
if item.type == 'bash_code_execution_tool_result':
content_item = item.content
if content_item.type == 'bash_code_execution_result':
for file in content_item.content:
if hasattr(file, 'file_id'):
file_ids.append(file.file_id)
return file_ids
# 3단계: Files API를 사용하여 파일 다운로드
for file_id in extract_file_ids(response):
file_metadata = client.beta.files.retrieve_metadata(
file_id=file_id,
betas=["files-api-2025-04-14"]
)
file_content = client.beta.files.download(
file_id=file_id,
betas=["files-api-2025-04-14"]
)
# 4단계: 디스크에 저장
file_content.write_to_file(file_metadata.filename)
print(f"Downloaded: {file_metadata.filename}")추가 Files API 작업:
# 파일 메타데이터 가져오기
file_info = client.beta.files.retrieve_metadata(
file_id=file_id,
betas=["files-api-2025-04-14"]
)
print(f"Filename: {file_info.filename}, Size: {file_info.size_bytes} bytes")
# 모든 파일 목록 조회
files = client.beta.files.list(betas=["files-api-2025-04-14"])
for file in files.data:
print(f"{file.filename} - {file.created_at}")
# 파일 삭제
client.beta.files.delete(
file_id=file_id,
betas=["files-api-2025-04-14"]
)Files API에 대한 전체 세부 사항은 Files API 문서를 참조하세요.
컨테이너 ID를 지정하여 여러 메시지에 걸쳐 동일한 컨테이너를 재사용합니다:
# 첫 번째 요청이 컨테이너를 생성합니다
response1 = client.beta.messages.create(
model="claude-opus-4-6",
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": "Analyze this sales data"}],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}]
)
# 동일한 컨테이너로 대화 계속
messages = [
{"role": "user", "content": "Analyze this sales data"},
{"role": "assistant", "content": response1.content},
{"role": "user", "content": "What was the total revenue?"}
]
response2 = client.beta.messages.create(
model="claude-opus-4-6",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"id": response1.container.id, # 컨테이너 재사용
"skills": [
{"type": "anthropic", "skill_id": "xlsx", "version": "latest"}
]
},
messages=messages,
tools=[{"type": "code_execution_20250825", "name": "code_execution"}]
)Skills는 여러 턴이 필요한 작업을 수행할 수 있습니다. pause_turn 중지 사유를 처리하세요:
messages = [{"role": "user", "content": "Process this large dataset"}]
max_retries = 10
response = client.beta.messages.create(
model="claude-opus-4-6",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"skills": [
{"type": "custom", "skill_id": "skill_01AbCdEfGhIjKlMnOpQrStUv", "version": "latest"}
]
},
messages=messages,
tools=[{"type": "code_execution_20250825", "name": "code_execution"}]
)
# 장시간 작업을 위한 pause_turn 처리
for i in range(max_retries):
if response.stop_reason != "pause_turn":
break
messages.append({"role": "assistant", "content": response.content})
response = client.beta.messages.create(
model="claude-opus-4-6",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"id": response.container.id,
"skills": [
{"type": "custom", "skill_id": "skill_01AbCdEfGhIjKlMnOpQrStUv", "version": "latest"}
]
},
messages=messages,
tools=[{"type": "code_execution_20250825", "name": "code_execution"}]
)응답에 pause_turn 중지 사유가 포함될 수 있으며, 이는 API가 장시간 실행되는 Skill 작업을 일시 중지했음을 나타냅니다. Claude가 턴을 계속할 수 있도록 응답을 그대로 후속 요청에 제공하거나, 대화를 중단하고 추가 안내를 제공하려면 콘텐츠를 수정할 수 있습니다.
복잡한 워크플로를 처리하기 위해 단일 요청에서 여러 Skills를 결합합니다:
response = client.beta.messages.create(
model="claude-opus-4-6",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"skills": [
{
"type": "anthropic",
"skill_id": "xlsx",
"version": "latest"
},
{
"type": "anthropic",
"skill_id": "pptx",
"version": "latest"
},
{
"type": "custom",
"skill_id": "skill_01AbCdEfGhIjKlMnOpQrStUv",
"version": "latest"
}
]
},
messages=[{
"role": "user",
"content": "Analyze sales data and create a presentation"
}],
tools=[{
"type": "code_execution_20250825",
"name": "code_execution"
}]
)커스텀 Skill을 업로드하여 워크스페이스에서 사용할 수 있게 합니다. 디렉토리 경로 또는 개별 파일 객체를 사용하여 업로드할 수 있습니다.
import anthropic
client = anthropic.Anthropic()
# 옵션 1: files_from_dir 헬퍼 사용 (Python 전용, 권장)
from anthropic.lib import files_from_dir
skill = client.beta.skills.create(
display_title="Financial Analysis",
files=files_from_dir("/path/to/financial_analysis_skill"),
betas=["skills-2025-10-02"]
)
# 옵션 2: zip 파일 사용
skill = client.beta.skills.create(
display_title="Financial Analysis",
files=[("skill.zip", open("financial_analysis_skill.zip", "rb"))],
betas=["skills-2025-10-02"]
)
# 옵션 3: 파일 튜플 사용 (filename, file_content, mime_type)
skill = client.beta.skills.create(
display_title="Financial Analysis",
files=[
("financial_skill/SKILL.md", open("financial_skill/SKILL.md", "rb"), "text/markdown"),
("financial_skill/analyze.py", open("financial_skill/analyze.py", "rb"), "text/x-python"),
],
betas=["skills-2025-10-02"]
)
print(f"Created skill: {skill.id}")
print(f"Latest version: {skill.latest_version}")요구 사항:
name: 최대 64자, 소문자/숫자/하이픈만 허용, XML 태그 불가, 예약어 불가 ("anthropic", "claude")description: 최대 1024자, 비어있지 않아야 함, XML 태그 불가전체 요청/응답 스키마는 Skill 생성 API 레퍼런스를 참조하세요.
Anthropic 사전 구축 Skills와 커스텀 Skills를 포함하여 워크스페이스에서 사용 가능한 모든 Skills를 조회합니다. source 매개변수를 사용하여 Skill 유형별로 필터링합니다:
# 모든 Skills 목록 조회
skills = client.beta.skills.list(
betas=["skills-2025-10-02"]
)
for skill in skills.data:
print(f"{skill.id}: {skill.display_title} (source: {skill.source})")
# 커스텀 Skills만 목록 조회
custom_skills = client.beta.skills.list(
source="custom",
betas=["skills-2025-10-02"]
)페이지네이션 및 필터링 옵션은 Skills 목록 API 레퍼런스를 참조하세요.
특정 Skill에 대한 세부 정보를 가져옵니다:
skill = client.beta.skills.retrieve(
skill_id="skill_01AbCdEfGhIjKlMnOpQrStUv",
betas=["skills-2025-10-02"]
)
print(f"Skill: {skill.display_title}")
print(f"Latest version: {skill.latest_version}")
print(f"Created: {skill.created_at}")Skill을 삭제하려면 먼저 모든 버전을 삭제해야 합니다:
# 1단계: 모든 버전 삭제
versions = client.beta.skills.versions.list(
skill_id="skill_01AbCdEfGhIjKlMnOpQrStUv",
betas=["skills-2025-10-02"]
)
for version in versions.data:
client.beta.skills.versions.delete(
skill_id="skill_01AbCdEfGhIjKlMnOpQrStUv",
version=version.version,
betas=["skills-2025-10-02"]
)
# 2단계: Skill 삭제
client.beta.skills.delete(
skill_id="skill_01AbCdEfGhIjKlMnOpQrStUv",
betas=["skills-2025-10-02"]
)기존 버전이 있는 Skill을 삭제하려고 하면 400 오류가 반환됩니다.
Skills는 업데이트를 안전하게 관리하기 위한 버전 관리를 지원합니다:
Anthropic 관리 Skills:
20251013커스텀 Skills:
1759178010641129"latest"를 사용하세요# 새 버전 생성
from anthropic.lib import files_from_dir
new_version = client.beta.skills.versions.create(
skill_id="skill_01AbCdEfGhIjKlMnOpQrStUv",
files=files_from_dir("/path/to/updated_skill"),
betas=["skills-2025-10-02"]
)
# 특정 버전 사용
response = client.beta.messages.create(
model="claude-opus-4-6",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"skills": [{
"type": "custom",
"skill_id": "skill_01AbCdEfGhIjKlMnOpQrStUv",
"version": new_version.version
}]
},
messages=[{"role": "user", "content": "Use updated Skill"}],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}]
)
# 최신 버전 사용
response = client.beta.messages.create(
model="claude-opus-4-6",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"skills": [{
"type": "custom",
"skill_id": "skill_01AbCdEfGhIjKlMnOpQrStUv",
"version": "latest"
}]
},
messages=[{"role": "user", "content": "Use latest Skill version"}],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}]
)전체 세부 사항은 Skill 버전 생성 API 레퍼런스를 참조하세요.
컨테이너에서 Skills를 지정하면:
/skills/{directory}/에 복사됩니다점진적 공개 아키텍처는 효율적인 컨텍스트 사용을 보장합니다—Claude는 필요할 때만 전체 Skill 지침을 로드합니다.
브랜드 & 커뮤니케이션
프로젝트 관리
비즈니스 운영
콘텐츠 제작
데이터 분석
개발 & 자동화
Excel과 커스텀 DCF 분석 Skills를 결합합니다:
# 커스텀 DCF 분석 Skill 생성
from anthropic.lib import files_from_dir
dcf_skill = client.beta.skills.create(
display_title="DCF Analysis",
files=files_from_dir("/path/to/dcf_skill"),
betas=["skills-2025-10-02"]
)
# Excel과 함께 사용하여 재무 모델 생성
response = client.beta.messages.create(
model="claude-opus-4-6",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"skills": [
{"type": "anthropic", "skill_id": "xlsx", "version": "latest"},
{"type": "custom", "skill_id": dcf_skill.id, "version": "latest"}
]
},
messages=[{
"role": "user",
"content": "Build a DCF valuation model for a SaaS company with the attached financials"
}],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}]
)name: 최대 64자, 소문자/숫자/하이픈만 허용, XML 태그 불가, 예약어 불가description: 최대 1024자, 비어 있지 않아야 함, XML 태그 불가Skills는 다음과 같은 제한이 있는 코드 실행 컨테이너에서 실행됩니다:
사용 가능한 패키지는 코드 실행 도구 문서를 참조하세요.
작업이 여러 문서 유형이나 도메인을 포함할 때 Skills를 결합하세요:
좋은 사용 사례:
피해야 할 사항:
프로덕션용:
# 안정성을 위해 특정 버전에 고정
container={
"skills": [{
"type": "custom",
"skill_id": "skill_01AbCdEfGhIjKlMnOpQrStUv",
"version": "1759178010641129" # 특정 버전
}]
}개발용:
# 활발한 개발 시 latest 사용
container={
"skills": [{
"type": "custom",
"skill_id": "skill_01AbCdEfGhIjKlMnOpQrStUv",
"version": "latest" # 항상 최신 버전 가져오기
}]
}프롬프트 캐싱을 사용할 때, 컨테이너의 Skills 목록을 변경하면 캐시가 무효화됩니다:
# 첫 번째 요청이 캐시를 생성
response1 = client.beta.messages.create(
model="claude-opus-4-6",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02", "prompt-caching-2024-07-31"],
container={
"skills": [
{"type": "anthropic", "skill_id": "xlsx", "version": "latest"}
]
},
messages=[{"role": "user", "content": "Analyze sales data"}],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}]
)
# Skills 추가/제거 시 캐시가 무효화됨
response2 = client.beta.messages.create(
model="claude-opus-4-6",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02", "prompt-caching-2024-07-31"],
container={
"skills": [
{"type": "anthropic", "skill_id": "xlsx", "version": "latest"},
{"type": "anthropic", "skill_id": "pptx", "version": "latest"} # 캐시 미스
]
},
messages=[{"role": "user", "content": "Create a presentation"}],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}]
)최적의 캐싱 성능을 위해 요청 간에 Skills 목록을 일관되게 유지하세요.
Skill 관련 오류를 우아하게 처리하세요:
try:
response = client.beta.messages.create(
model="claude-opus-4-6",
max_tokens=4096,
betas=["code-execution-2025-08-25", "skills-2025-10-02"],
container={
"skills": [
{"type": "custom", "skill_id": "skill_01AbCdEfGhIjKlMnOpQrStUv", "version": "latest"}
]
},
messages=[{"role": "user", "content": "Process data"}],
tools=[{"type": "code_execution_20250825", "name": "code_execution"}]
)
except anthropic.BadRequestError as e:
if "skill" in str(e):
print(f"Skill error: {e}")
# Skill 관련 오류 처리
else:
raiseWas this page helpful?