이 기능은 Zero Data Retention (ZDR)의 적용 대상입니다. 조직에 ZDR 계약이 체결되어 있는 경우, 이 기능을 통해 전송된 데이터는 API 응답이 반환된 후 저장되지 않습니다.
Claude는 문서에 대한 질문에 답변할 때 상세한 인용을 제공할 수 있어, 응답에서 정보 출처를 추적하고 검증하는 데 도움을 줍니다.
Haiku 3를 제외한 모든 활성 모델이 인용을 지원합니다.
이 양식을 사용하여 인용 기능에 대한 피드백과 제안을 공유해 주세요.
다음은 Messages API에서 인용을 사용하는 방법의 예시입니다:
client = anthropic.Anthropic()
response = client.messages.create(
model="claude-opus-4-8",
max_tokens=1024,
messages=[
{
"role": "user",
"content": [
{
"type": "document",
"source": {
"type": "text",
"media_type": "text/plain",
"data": "The grass is green. The sky is blue.",
},
"title": "My Document",
"context": "This is a trustworthy document.",
"citations": {"enabled": True},
},
{"type": "text", "text": "What color is the grass and sky?"},
],
}
],
)
print(response)프롬프트 기반 접근 방식과의 비교
프롬프트 기반 인용 솔루션과 비교할 때, 인용 기능은 다음과 같은 장점이 있습니다:
cited_text가 출력 토큰에 포함되지 않기 때문에 비용을 절감할 수 있습니다.cited_text가 추출되기 때문에, 인용은 제공된 문서에 대한 유효한 포인터를 포함하는 것이 보장됩니다.다음 단계에 따라 Claude와 인용을 통합하세요:
문서 제공 및 인용 활성화
citations.enabled=true를 설정하세요. 현재 인용은 요청 내 모든 문서에서 활성화되거나 모두 비활성화되어야 합니다.문서 처리
Claude가 인용된 응답 제공
자동 청킹 vs 사용자 지정 콘텐츠
기본적으로 일반 텍스트 및 PDF 문서는 자동으로 문장 단위로 청킹됩니다. 인용 단위에 대한 더 많은 제어가 필요한 경우(예: 글머리 기호 또는 대화 기록), 대신 사용자 지정 콘텐츠 문서를 사용하세요. 자세한 내용은 문서 유형을 참조하세요.
예를 들어, Claude가 RAG 청크에서 특정 문장을 인용할 수 있도록 하려면 각 RAG 청크를 일반 텍스트 문서에 넣어야 합니다. 그렇지 않고 추가 청킹을 원하지 않거나 추가 청킹을 사용자 지정하려는 경우, RAG 청크를 사용자 지정 콘텐츠 문서에 넣을 수 있습니다.
source 콘텐츠 내에 있는 텍스트는 인용될 수 있습니다.title과 context는 모델에 전달되지만 인용 콘텐츠로 사용되지 않는 선택적 필드입니다.title은 길이가 제한되어 있으므로, 문서 메타데이터를 텍스트 또는 문자열화된 JSON으로 저장하는 데 context 필드가 유용할 수 있습니다.content 목록을 기준으로 0부터 시작하며 끝 인덱스는 제외됩니다.cited_text 필드는 편의를 위해 제공되며 출력 토큰에 포함되지 않습니다.cited_text는 입력 토큰에도 포함되지 않습니다.인용은 프롬프트 캐싱, 토큰 계산 및 배치 처리를 포함한 다른 API 기능과 함께 작동합니다.
인용과 Structured Outputs는 호환되지 않습니다
인용은 Structured Outputs와 함께 사용할 수 없습니다. 사용자가 제공한 문서(Document 블록 또는 RequestSearchResultBlock)에서 인용을 활성화하고 output_config.format 매개변수(또는 더 이상 사용되지 않는 output_format 매개변수)도 포함하는 경우, API는 400 오류를 반환합니다.
이는 인용이 텍스트 출력과 인용 블록을 교차 배치해야 하는데, 이것이 structured outputs의 엄격한 JSON 스키마 제약 조건과 호환되지 않기 때문입니다.
인용과 프롬프트 캐싱은 함께 효과적으로 사용할 수 있습니다.
응답에서 생성된 인용 블록은 직접 캐시할 수 없지만, 참조하는 소스 문서는 캐시할 수 있습니다. 성능을 최적화하려면 최상위 문서 콘텐츠 블록에 cache_control을 적용하세요.
이 예시에서:
cache_control을 사용하여 캐시됩니다인용에는 세 가지 문서 유형이 지원됩니다. 문서는 메시지에 직접 제공하거나(base64, 텍스트 또는 URL) Files API를 통해 업로드하고 file_id로 참조할 수 있습니다:
| 유형 | 적합한 용도 | 청킹 | 인용 형식 |
|---|---|---|---|
| 일반 텍스트 | 간단한 텍스트 문서, 산문 | 문장 | 문자 인덱스(0부터 시작) |
| 텍스트 콘텐츠가 있는 PDF 파일 | 문장 | 페이지 번호(1부터 시작) | |
| 사용자 지정 콘텐츠 | 목록, 대화 기록, 특수 서식, 더 세분화된 인용 | 추가 청킹 없음 | 블록 인덱스(0부터 시작) |
.csv, .xlsx, .docx, .md 및 .txt 파일은 문서 블록으로 지원되지 않습니다. 이러한 파일은 일반 텍스트로 변환하여 메시지 콘텐츠에 직접 포함하세요. 다른 파일 형식 작업하기를 참조하세요.
일반 텍스트 문서는 자동으로 문장 단위로 청킹됩니다. 인라인으로 제공하거나 file_id로 참조하여 제공할 수 있습니다:
PDF 문서는 base64로 인코딩된 데이터, URL 또는 file_id로 제공할 수 있습니다. PDF 텍스트가 추출되어 문장 단위로 청킹됩니다. 이미지 인용은 아직 지원되지 않으므로, 문서를 스캔한 것이며 추출 가능한 텍스트가 없는 PDF는 인용할 수 없습니다.
사용자 지정 콘텐츠 문서는 인용 단위에 대한 제어를 제공합니다. 추가 청킹이 수행되지 않으며 제공된 콘텐츠 블록에 따라 청크가 모델에 제공됩니다.
{
"type": "document",
"source": {
"type": "content",
"content": [
{"type": "text", "text": "First chunk"},
{"type": "text", "text": "Second chunk"},
],
},
"title": "Document Title", # optional
"context": "Context about the document that will not be cited from", # optional
"citations": {"enabled": True},
}인용이 활성화되면 응답에는 인용이 포함된 여러 텍스트 블록이 포함됩니다:
{
"content": [
{"type": "text", "text": "According to the document, "},
{
"type": "text",
"text": "the grass is green",
"citations": [
{
"type": "char_location",
"cited_text": "The grass is green.",
"document_index": 0,
"document_title": "Example Document",
"start_char_index": 0,
"end_char_index": 20,
}
],
},
{"type": "text", "text": " and "},
{
"type": "text",
"text": "the sky is blue",
"citations": [
{
"type": "char_location",
"cited_text": "The sky is blue.",
"document_index": 0,
"document_title": "Example Document",
"start_char_index": 20,
"end_char_index": 36,
}
],
},
{
"type": "text",
"text": ". Information from page 5 states that ",
},
{
"type": "text",
"text": "water is essential",
"citations": [
{
"type": "page_location",
"cited_text": "Water is essential for life.",
"document_index": 1,
"document_title": "PDF Document",
"start_page_number": 5,
"end_page_number": 6,
}
],
},
{
"type": "text",
"text": ". The custom document mentions ",
},
{
"type": "text",
"text": "important findings",
"citations": [
{
"type": "content_block_location",
"cited_text": "These are important findings.",
"document_index": 2,
"document_title": "Custom Content Document",
"start_block_index": 0,
"end_block_index": 1,
}
],
},
]
}스트리밍 응답의 경우, 현재 text 콘텐츠 블록의 citations 목록에 추가될 단일 인용을 포함하는 citations_delta 유형이 포함됩니다.
Was this page helpful?
client = anthropic.Anthropic()
# 긴 문서 콘텐츠 (예: 기술 문서)
long_document = (
"This is a very long document with thousands of words..." + " ... " * 1000
) # Minimum cacheable length
response = client.messages.create(
model="claude-opus-4-8",
max_tokens=1024,
messages=[
{
"role": "user",
"content": [
{
"type": "document",
"source": {
"type": "text",
"media_type": "text/plain",
"data": long_document,
},
"citations": {"enabled": True},
"cache_control": {
"type": "ephemeral"
}, # Cache the document content
},
{
"type": "text",
"text": "What does this document say about API features?",
},
],
}
],
)
print(response)