From 4073dd4efb53e82468c7736eb56fc9254b49f0d8 Mon Sep 17 00:00:00 2001 From: afourney Date: Wed, 13 Nov 2024 21:06:55 -0800 Subject: [PATCH] Have Console print multimodal messages nicely. (#4179) --- .../src/autogen_agentchat/task/_console.py | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/python/packages/autogen-agentchat/src/autogen_agentchat/task/_console.py b/python/packages/autogen-agentchat/src/autogen_agentchat/task/_console.py index 71344eb7afd9..7e4d1cab9879 100644 --- a/python/packages/autogen-agentchat/src/autogen_agentchat/task/_console.py +++ b/python/packages/autogen-agentchat/src/autogen_agentchat/task/_console.py @@ -1,11 +1,11 @@ import sys import time -from typing import AsyncGenerator +from typing import AsyncGenerator, List from autogen_core.components.models import RequestUsage from autogen_agentchat.base import TaskResult -from autogen_agentchat.messages import AgentMessage +from autogen_agentchat.messages import AgentMessage, MultiModalMessage async def Console(stream: AsyncGenerator[AgentMessage | TaskResult, None]) -> None: @@ -27,9 +27,22 @@ async def Console(stream: AsyncGenerator[AgentMessage | TaskResult, None]) -> No ) sys.stdout.write(output) else: - output = f"{'-' * 10} {message.source} {'-' * 10}\n{message.content}\n" + output = f"{'-' * 10} {message.source} {'-' * 10}\n{_message_to_str(message)}\n" if message.models_usage: output += f"[Prompt tokens: {message.models_usage.prompt_tokens}, Completion tokens: {message.models_usage.completion_tokens}]\n" total_usage.completion_tokens += message.models_usage.completion_tokens total_usage.prompt_tokens += message.models_usage.prompt_tokens sys.stdout.write(output) + + +def _message_to_str(message: AgentMessage) -> str: + if isinstance(message, MultiModalMessage): + result: List[str] = [] + for c in message.content: + if isinstance(c, str): + result.append(c) + else: + result.append("") + return "\n".join(result) + else: + return f"{message.content}"