Agent Skills erweitern Claude mit spezialisierten Fähigkeiten, die Claude autonom aufruft, wenn relevant. Skills werden als SKILL.md-Dateien verpackt, die Anweisungen, Beschreibungen und optionale unterstützende Ressourcen enthalten.
Umfassende Informationen zu Skills, einschließlich Vorteile, Architektur und Authoring-Richtlinien, finden Sie in der Agent Skills-Übersicht.
Bei Verwendung des Claude Agent SDK sind Skills:
SKILL.md-Dateien in spezifischen Verzeichnissen (.claude/skills/)"Skill" zu Ihrem allowed_tools hinzu, um Skills zu aktivierenIm Gegensatz zu Subagenten (die programmatisch definiert werden können) müssen Skills als Dateisystem-Artefakte erstellt werden. Das SDK bietet keine programmatische API zum Registrieren von Skills.
Um Skills mit dem SDK zu verwenden, fügen Sie "Skill" in Ihre allowed_tools-Konfiguration ein. Nach der Aktivierung entdeckt Claude automatisch Skills aus dem .claude/skills/-Verzeichnis Ihres Projekts und ruft sie auf, wenn sie für die Anfrage des Benutzers relevant sind.
Skills werden automatisch aus designierten Dateisystem-Verzeichnissen geladen:
.claude/skills/): Mit Ihrem Team über git geteilt~/.claude/skills/): Persönliche Skills über alle Projekte hinwegDas SDK lädt Skills aus diesen Verzeichnissen basierend auf Ihrer cwd-Einstellung (aktuelles Arbeitsverzeichnis).
Skills werden als Verzeichnisse definiert, die eine SKILL.md-Datei mit YAML-Frontmatter und Markdown-Inhalt enthalten. Das description-Feld bestimmt, wann Claude Ihren Skill aufruft.
Beispiel-Verzeichnisstruktur:
.claude/skills/processing-pdfs/
└── SKILL.mdVollständige Anleitung zum Erstellen von Skills, einschließlich SKILL.md-Struktur, mehrdatei-Skills und Beispiele, finden Sie unter:
Das allowed-tools-Frontmatter-Feld in SKILL.md wird nur unterstützt, wenn Sie Claude Code CLI direkt verwenden. Es gilt nicht, wenn Sie Skills über das SDK verwenden.
Bei Verwendung des SDK steuern Sie den Tool-Zugriff über die Hauptoption allowedTools in Ihrer Abfragekonfiguration.
Um Tools für Skills in SDK-Anwendungen einzuschränken, verwenden Sie die allowedTools-Option:
Import-Anweisungen aus dem ersten Beispiel werden in den folgenden Code-Snippets angenommen.
options = ClaudeAgentOptions(
allowed_tools=["Skill", "Read", "Grep", "Glob"] # Restricted toolset
)
async for message in query(
prompt="Analyze the codebase structure",
options=options
):
print(message)Um zu sehen, welche Skills in Ihrer SDK-Anwendung verfügbar sind, fragen Sie einfach Claude:
options = ClaudeAgentOptions(
allowed_tools=["Skill"]
)
async for message in query(
prompt="What Skills are available?",
options=options
):
print(message)Claude listet die verfügbaren Skills basierend auf Ihrem aktuellen Arbeitsverzeichnis und installierten Plugins auf.
Testen Sie Skills, indem Sie Fragen stellen, die ihren Beschreibungen entsprechen:
options = ClaudeAgentOptions(
cwd="/path/to/project",
allowed_tools=["Skill", "Read", "Bash"]
)
async for message in query(
prompt="Extract text from invoice.pdf",
options=options
):
print(message)Claude ruft automatisch den relevanten Skill auf, wenn die Beschreibung Ihrer Anfrage entspricht.
Arbeitsverzeichnis überprüfen: Das SDK lädt Skills relativ zur cwd-Option. Stellen Sie sicher, dass sie auf ein Verzeichnis verweist, das .claude/skills/ enthält:
# Ensure your cwd points to the directory containing .claude/skills/
options = ClaudeAgentOptions(
cwd="/path/to/project", # Must contain .claude/skills/
allowed_tools=["Skill"]
)Siehe den Abschnitt "Verwenden von Skills mit dem SDK" oben für das vollständige Muster.
Dateisystem-Standort überprüfen:
# Check project Skills
ls .claude/skills/*/SKILL.md
# Check personal Skills
ls ~/.claude/skills/*/SKILL.mdÜberprüfen Sie, ob das Skill-Tool aktiviert ist: Bestätigen Sie, dass "Skill" in Ihrem allowedTools enthalten ist.
Überprüfen Sie die Beschreibung: Stellen Sie sicher, dass sie spezifisch ist und relevante Schlüsselwörter enthält. Siehe Agent Skills Best Practices für Anleitung zum Schreiben effektiver Beschreibungen.
Für allgemeine Skills-Fehlerbehebung (YAML-Syntax, Debugging usw.) siehe den Claude Code Skills-Fehlerbehebungsabschnitt.
import asyncio
from claude_agent_sdk import query, ClaudeAgentOptions
async def main():
options = ClaudeAgentOptions(
cwd="/path/to/project", # Project with .claude/skills/
allowed_tools=["Skill", "Read", "Write", "Bash"] # Enable Skill tool
)
async for message in query(
prompt="Help me process this PDF document",
options=options
):
print(message)
asyncio.run(main())