As saídas estruturadas restringem as respostas do Claude para seguir um esquema específico, garantindo uma saída válida e analisável para processamento posterior. As saídas estruturadas fornecem dois recursos complementares:
output_config.format): Obtenha a resposta do Claude em um formato JSON específicostrict: true): Garanta a validação de esquema em nomes e entradas de ferramentasVocê pode usar esses recursos de forma independente ou em conjunto na mesma requisição.
As saídas estruturadas estão disponíveis de forma geral na API do Claude para Claude Fable 5, Claude Mythos 5, Claude Opus 4.8, Claude Mythos Preview, Claude Opus 4.7, Claude Opus 4.6, Claude Sonnet 4.6, Claude Sonnet 4.5, Claude Opus 4.5 e Claude Haiku 4.5. No Amazon Bedrock, as saídas estruturadas estão disponíveis de forma geral para Claude Opus 4.6, Claude Sonnet 4.6, Claude Sonnet 4.5, Claude Opus 4.5 e Claude Haiku 4.5; Claude Opus 4.7 e Claude Mythos Preview estão disponíveis através do Claude no Amazon Bedrock (o endpoint Bedrock da Messages API). As saídas estruturadas estão disponíveis no Claude Platform na AWS e em beta no Microsoft Foundry. No Vertex AI, as saídas estruturadas estão disponíveis de forma geral para Claude Fable 5, Claude Mythos 5, Claude Opus 4.8, Claude Mythos Preview, Claude Opus 4.7, Claude Opus 4.6, Claude Sonnet 4.6, Claude Sonnet 4.5, Claude Opus 4.5 e Claude Haiku 4.5.
Este recurso se qualifica para Zero Data Retention (ZDR) com retenção técnica limitada. Consulte a seção Retenção de dados para detalhes sobre o que é retido e por quê.
Migrando do beta? O parâmetro output_format foi movido para output_config.format, e os cabeçalhos beta não são mais necessários. O antigo cabeçalho beta (structured-outputs-2025-11-13) e o parâmetro output_format continuarão funcionando por um período de transição. Consulte os exemplos de código a seguir para o formato atualizado da API.
Sem saídas estruturadas, o Claude pode gerar respostas JSON malformadas ou entradas de ferramentas inválidas que quebram suas aplicações. Mesmo com prompts cuidadosos, você pode encontrar:
As saídas estruturadas garantem respostas em conformidade com o esquema por meio de decodificação restrita:
JSON.parse()As saídas JSON controlam o formato de resposta do Claude, garantindo que o Claude retorne JSON válido correspondente ao seu esquema. Use saídas JSON quando precisar:
Formato de resposta: JSON válido correspondente ao seu esquema em response.content[0].text
{
"name": "John Smith",
"email": "[email protected]",
"plan_interest": "Enterprise",
"demo_requested": true
}Defina seu esquema JSON
Crie um esquema JSON que descreva a estrutura que você deseja que o Claude siga. O esquema usa o formato padrão JSON Schema com algumas limitações (consulte Limitações do JSON Schema).
Adicione o parâmetro output_config.format
Inclua o parâmetro output_config.format na sua requisição de API com type: "json_schema" e sua definição de esquema.
Analise a resposta
A resposta do Claude é um JSON válido correspondente ao seu esquema, retornado em response.content[0].text.
Os SDKs fornecem auxiliares que facilitam o trabalho com saídas JSON, incluindo transformação de esquema, validação automática e integração com bibliotecas de esquema populares.
O método client.messages.parse() do SDK Python ainda aceita output_format como um parâmetro de conveniência e o traduz internamente para output_config.format. Outros SDKs exigem output_config diretamente. Os exemplos a seguir mostram a sintaxe dos auxiliares do SDK.
Em vez de escrever esquemas JSON brutos, você pode usar ferramentas de definição de esquema familiares na sua linguagem:
client.messages.parse()zodOutputFormat() ou literais de JSON Schema tipados com jsonSchemaOutputFormat()outputConfig(Class<T>)Anthropic::BaseModel com output_config: {format: Model}StructuredOutputModel com outputConfig: ['format' => MyClass::class]Cada SDK fornece auxiliares que facilitam o trabalho com saídas estruturadas. Consulte as páginas individuais de cada SDK para obter detalhes completos.
Os SDKs Python, TypeScript, Ruby e PHP transformam automaticamente esquemas com recursos não suportados. Os SDKs C# e Go aplicam as mesmas transformações quando o esquema é derivado de um tipo nativo (Create<T>() em C#; reflexão de struct ou BetaJSONSchemaOutputFormat() na API beta do Go). As etapas de transformação:
minimum, maximum, minLength, maxLength)additionalProperties: false a todos os objetosIsso significa que o Claude recebe um esquema simplificado, mas seu código ainda aplica todas as restrições por meio de validação.
Exemplo: Um campo Pydantic com minimum: 100 torna-se um inteiro simples no esquema enviado, mas o SDK atualiza a descrição para "Must be at least 100" e valida a resposta contra a restrição original.
Para aplicar conformidade com JSON Schema em entradas de ferramentas com amostragem restrita por gramática, consulte Uso estrito de ferramentas.
As saídas JSON e o uso estrito de ferramentas resolvem problemas diferentes e funcionam juntos:
Quando combinados, o Claude pode chamar ferramentas com parâmetros garantidamente válidos E retornar respostas JSON estruturadas. Isso é útil para fluxos de trabalho agênticos onde você precisa tanto de chamadas de ferramentas confiáveis quanto de saídas finais estruturadas.
As saídas estruturadas usam amostragem restrita com artefatos de gramática compilados. Isso introduz algumas características de desempenho a serem observadas:
name ou description não invalida o cacheAo usar saídas estruturadas, o Claude recebe automaticamente um prompt do sistema adicional explicando o formato de saída esperado. Isso significa que:
output_config.format invalidará qualquer cache de prompt para aquele thread de conversaAs saídas estruturadas suportam JSON Schema padrão com algumas limitações. Tanto as saídas JSON quanto o uso estrito de ferramentas compartilham essas limitações.
Os SDKs Python, TypeScript, Ruby e PHP podem transformar automaticamente esquemas com recursos não suportados, removendo-os e adicionando restrições às descrições dos campos. Os SDKs C# e Go fazem o mesmo quando o esquema é derivado de um tipo nativo. Consulte Métodos específicos do SDK para obter detalhes.
Ao usar saídas estruturadas, as propriedades em objetos mantêm sua ordenação definida no seu esquema, com uma ressalva importante: propriedades obrigatórias aparecem primeiro, seguidas por propriedades opcionais.
Por exemplo, dado este esquema:
{
"type": "object",
"properties": {
"notes": { "type": "string" },
"name": { "type": "string" },
"email": { "type": "string" },
"age": { "type": "integer" }
},
"required": ["name", "email"],
"additionalProperties": false
}A saída ordenará as propriedades como:
name (obrigatória, na ordem do esquema)email (obrigatória, na ordem do esquema)notes (opcional, na ordem do esquema)age (opcional, na ordem do esquema)Isso significa que a saída pode ser assim:
{
"name": "John Smith",
"email": "[email protected]",
"notes": "Interested in enterprise plan",
"age": 35
}Se a ordem das propriedades na saída for importante para sua aplicação, marque todas as propriedades como obrigatórias ou leve em conta essa reordenação na sua lógica de análise.
Embora as saídas estruturadas garantam conformidade com o esquema na maioria dos casos, há cenários em que a saída pode não corresponder ao seu esquema:
Recusas (stop_reason: "refusal")
O Claude mantém suas propriedades de segurança e utilidade mesmo ao usar saídas estruturadas. Se o Claude recusar uma requisição por motivos de segurança:
stop_reason: "refusal"Limite de tokens atingido (stop_reason: "max_tokens")
Se a resposta for cortada devido ao atingimento do limite de max_tokens:
stop_reason: "max_tokens"max_tokens mais alto para obter a saída estruturada completaAs saídas estruturadas funcionam compilando seus esquemas JSON em uma gramática que restringe a saída do Claude. Esquemas mais complexos produzem gramáticas maiores que levam mais tempo para compilar. Para proteger contra tempos de compilação excessivos, a API impõe vários limites de complexidade.
Os seguintes limites se aplicam a todas as requisições com output_config.format ou strict: true:
| Limite | Valor | Descrição |
|---|---|---|
| Ferramentas estritas por requisição | 20 | Número máximo de ferramentas com strict: true. Ferramentas não estritas não contam para esse limite. |
| Parâmetros opcionais | 24 | Total de parâmetros opcionais em todos os esquemas de ferramentas estritas e esquemas de saída JSON. Cada parâmetro não listado em required conta para esse limite. |
| Parâmetros com tipos de união | 16 | Total de parâmetros que usam anyOf ou arrays de tipo (por exemplo, "type": ["string", "null"]) em todos os esquemas estritos. Esses são especialmente custosos porque criam custo de compilação exponencial. |
Esses limites se aplicam ao total combinado em todos os esquemas estritos em uma única requisição. Por exemplo, se você tiver 4 ferramentas estritas com 6 parâmetros opcionais cada, você atingirá o limite de 24 parâmetros mesmo que nenhuma ferramenta individual pareça complexa.
Além dos limites explícitos na tabela anterior, há limites internos adicionais no tamanho da gramática compilada. Esses limites existem porque a complexidade do esquema não se reduz a uma única dimensão: recursos como parâmetros opcionais, tipos de união, objetos aninhados e número de ferramentas interagem entre si de maneiras que podem tornar a gramática compilada desproporcionalmente grande.
Quando esses limites são excedidos, você receberá um erro 400 com a mensagem "Schema is too complex for compilation." Esses erros significam que a complexidade combinada dos seus esquemas excede o que pode ser compilado de forma eficiente, mesmo que cada limite individual na tabela anterior seja satisfeito. Como última salvaguarda, a API também impõe um tempo limite de compilação de 180 segundos. Esquemas que passam em todas as verificações explícitas, mas produzem gramáticas compiladas muito grandes, podem atingir esse tempo limite.
Se você estiver atingindo limites de complexidade, tente estas estratégias em ordem:
Marque apenas ferramentas críticas como estritas. Se você tiver muitas ferramentas, reserve isso para ferramentas onde violações de esquema causam problemas reais e confie na aderência natural do Claude para ferramentas mais simples.
Reduza parâmetros opcionais. Torne os parâmetros required sempre que possível. Cada parâmetro opcional aproximadamente dobra uma parte do espaço de estados da gramática. Se um parâmetro sempre tem um padrão razoável, considere torná-lo obrigatório e fazer com que o Claude forneça esse padrão explicitamente.
Simplifique estruturas aninhadas. Objetos profundamente aninhados com campos opcionais aumentam a complexidade. Achate as estruturas sempre que possível.
Divida em múltiplas requisições. Se você tiver muitas ferramentas estritas, considere dividi-las em requisições separadas ou subagentes.
Para problemas persistentes com esquemas válidos, entre em contato com o suporte com sua definição de esquema.
Prompts e respostas são processados com ZDR ao usar saídas estruturadas. No entanto, o próprio esquema JSON é temporariamente armazenado em cache por até 24 horas desde o último uso para fins de otimização. Nenhum dado de prompt ou resposta é retido além da resposta da API.
As saídas estruturadas são elegíveis para HIPAA, mas PHI não deve ser incluído em definições de esquema JSON. A API compila esquemas JSON em gramáticas que são armazenadas em cache separadamente do conteúdo da mensagem, e esses esquemas em cache não recebem as mesmas proteções de PHI que prompts e respostas. Não inclua PHI em nomes de propriedades de esquema, valores enum, valores const ou expressões regulares pattern. PHI deve aparecer apenas no conteúdo da mensagem (prompts e respostas), onde é protegido sob as salvaguardas da HIPAA.
Para elegibilidade de ZDR e HIPAA em todos os recursos, consulte API e retenção de dados.
Funciona com:
output_config.format) e uso estrito de ferramentas (strict: true) juntos na mesma requisiçãoIncompatível com:
output_config.format.Escopo da gramática: As gramáticas se aplicam apenas à saída direta do Claude, não a chamadas de uso de ferramentas, resultados de ferramentas ou tags de pensamento (ao usar Pensamento Estendido). O estado da gramática é redefinido entre seções, permitindo que o Claude pense livremente enquanto ainda produz saída estruturada na resposta final.
Was this page helpful?
client = anthropic.Anthropic()
response = client.messages.create(
model="claude-opus-4-8",
max_tokens=1024,
messages=[
{
"role": "user",
"content": "Extract the key information from this email: John Smith ([email protected]) is interested in our Enterprise plan and wants to schedule a demo for next Tuesday at 2pm.",
}
],
output_config={
"format": {
"type": "json_schema",
"schema": {
"type": "object",
"properties": {
"name": {"type": "string"},
"email": {"type": "string"},
"plan_interest": {"type": "string"},
"demo_requested": {"type": "boolean"},
},
"required": ["name", "email", "plan_interest", "demo_requested"],
"additionalProperties": False,
},
}
},
)
print(response.content[0].text)Create<T>()output_configoutput_configfrom pydantic import BaseModel
from anthropic import Anthropic
class ContactInfo(BaseModel):
name: str
email: str
plan_interest: str
demo_requested: bool
client = Anthropic()
response = client.messages.parse(
model="claude-opus-4-8",
max_tokens=1024,
messages=[
{
"role": "user",
"content": "Extract the key information from this email: John Smith ([email protected]) is interested in our Enterprise plan and wants to schedule a demo for next Tuesday at 2pm.",
}
],
output_format=ContactInfo,
)
print(response.parsed_output)response = client.messages.create(
model="claude-opus-4-8",
max_tokens=1024,
messages=[
{
"role": "user",
"content": "Help me plan a trip to Paris departing May 15, 2026",
}
],
# Saídas JSON: formato de resposta estruturado
output_config={
"format": {
"type": "json_schema",
"schema": {
"type": "object",
"properties": {
"summary": {"type": "string"},
"next_steps": {"type": "array", "items": {"type": "string"}},
},
"required": ["summary", "next_steps"],
"additionalProperties": False,
},
}
},
# Uso estrito de ferramentas: parâmetros de ferramenta garantidos
tools=[
{
"name": "search_flights",
"strict": True,
"input_schema": {
"type": "object",
"properties": {
"destination": {"type": "string"},
"date": {"type": "string", "format": "date"},
},
"required": ["destination", "date"],
"additionalProperties": False,
},
}
],
)
print(response)