결과
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 프로퍼티에는 마지막으로 실행된 에이전트가 담겨 있습니다. 애플리케이션에 따라, 다음에 사용자가 무언가를 입력할 때 유용한 경우가 많습니다. 예를 들어, 프런트라인 분류 에이전트가 언어별 에이전트로 핸드오프하는 경우, 마지막 에이전트를 저장해 두었다가 사용자가 다음에 메시지를 보낼 때 재사용할 수 있습니다.
새 항목
new_items 프로퍼티에는 실행 중 생성된 새 항목이 담겨 있습니다. 항목은 RunItems입니다. 실행 항목은 LLM이 생성한 원문 항목을 래핑합니다.
MessageOutputItem은 LLM의 메시지를 나타냅니다. 원문 항목은 생성된 메시지입니다.HandoffCallItem은 LLM이 핸드오프 도구를 호출했음을 나타냅니다. 원문 항목은 LLM의 도구 호출 항목입니다.HandoffOutputItem은 핸드오프가 발생했음을 나타냅니다. 원문 항목은 핸드오프 도구 호출에 대한 도구 응답입니다. 항목에서 소스/타깃 에이전트에도 접근할 수 있습니다.ToolCallItem은 LLM이 도구를 호출했음을 나타냅니다.ToolCallOutputItem은 도구가 호출되었음을 나타냅니다. 원문 항목은 도구 응답입니다. 항목에서 도구 출력에도 접근할 수 있습니다.ReasoningItem은 LLM의 추론 항목을 나타냅니다. 원문 항목은 생성된 추론입니다.
기타 정보
가드레일 결과
input_guardrail_results와 output_guardrail_results 프로퍼티에는 (있는 경우) 가드레일 결과가 담겨 있습니다. 가드레일 결과에는 로깅하거나 저장하기 좋은 유용한 정보가 포함될 수 있으므로, 이를 제공해 드립니다.
도구 가드레일 결과는 tool_input_guardrail_results와 tool_output_guardrail_results로 별도 제공됩니다. 이 가드레일은 도구에 부착될 수 있으며, 해당 도구 호출은 에이전트 워크플로우 중에 가드레일을 실행합니다.
원문 응답
raw_responses 프로퍼티에는 LLM이 생성한 ModelResponses가 담겨 있습니다.
원본 입력
input 프로퍼티에는 run 메서드에 제공한 원본 입력이 담겨 있습니다. 대부분의 경우 필요하지 않지만, 필요한 경우를 대비해 제공됩니다.