결과
Runner.run
메서드를 호출하면 다음 중 하나를 받습니다:
RunResult
(run
또는run_sync
호출 시)RunResultStreaming
(run_streamed
호출 시)
두 객체 모두 RunResultBase
를 상속하며, 대부분의 유용한 정보가 여기에 포함됩니다.
최종 출력
final_output
속성에는 마지막으로 실행된 에이전트의 최종 출력이 들어 있습니다. 이는 다음 중 하나입니다:
- 마지막 에이전트에
output_type
이 정의되지 않았다면str
- 에이전트에 출력 타입이 정의되었다면
last_agent.output_type
타입의 객체
Note
final_output
의 타입은 Any
입니다. 핸드오프 때문에 정적 타이핑을 할 수 없습니다. 핸드오프가 발생하면 어떤 에이전트든 마지막 에이전트가 될 수 있으므로, 가능한 출력 타입 집합을 정적으로 알 수 없습니다.
다음 턴 입력
result.to_input_list()
를 사용하면 결과를 입력 리스트로 변환할 수 있으며, 여기에 제공한 원래 입력과 에이전트 실행 중 생성된 항목이 연결됩니다. 이를 통해 한 번의 에이전트 실행 결과를 다른 실행에 전달하거나, 루프에서 실행하면서 매번 새로운 사용자 입력을 덧붙이기 편리합니다.
마지막 에이전트
last_agent
속성에는 마지막으로 실행된 에이전트가 포함됩니다. 애플리케이션에 따라, 이는 사용자가 다음에 입력할 때 유용한 경우가 많습니다. 예를 들어, 1차 분류(트리아지) 에이전트가 언어별 에이전트로 핸드오프하는 경우, 마지막 에이전트를 저장해 두었다가 사용자가 다음에 에이전트에게 메시지를 보낼 때 재사용할 수 있습니다.
새 항목
new_items
속성에는 실행 중에 생성된 새 항목이 포함됩니다. 항목은 RunItem
입니다. 실행 항목은 LLM이 생성한 원문 항목을 래핑합니다.
MessageOutputItem
은 LLM의 메시지를 나타냅니다. 원문 항목은 생성된 메시지입니다.HandoffCallItem
은 LLM이 핸드오프 도구를 호출했음을 나타냅니다. 원문 항목은 LLM의 도구 호출 항목입니다.HandoffOutputItem
은 핸드오프가 발생했음을 나타냅니다. 원문 항목은 핸드오프 도구 호출에 대한 도구 응답입니다. 항목에서 소스/타깃 에이전트에도 접근할 수 있습니다.ToolCallItem
은 LLM이 도구를 호출했음을 나타냅니다.ToolCallOutputItem
은 도구가 호출되었음을 나타냅니다. 원문 항목은 도구 응답입니다. 항목에서 도구 출력에도 접근할 수 있습니다.ReasoningItem
은 LLM의 추론 항목을 나타냅니다. 원문 항목은 생성된 추론입니다.
기타 정보
가드레일 결과
input_guardrail_results
와 output_guardrail_results
속성에는 (있는 경우) 가드레일의 결과가 포함됩니다. 가드레일 결과에는 로깅하거나 저장하고 싶은 유용한 정보가 포함될 수 있어, 이를 제공해 드립니다.
원문 응답
raw_responses
속성에는 LLM이 생성한 ModelResponse
가 포함됩니다.
원본 입력
input
속성에는 run
메서드에 제공한 원본 입력이 들어 있습니다. 대부분의 경우 필요하지 않지만, 필요한 경우를 대비해 제공됩니다.