跳转至

智能体可视化

智能体可视化可使用 Graphviz 生成智能体及其关系的结构化图形表示。这有助于理解智能体、工具与任务转移在应用中的交互方式。

安装

安装可选的 viz 依赖组:

pip install "openai-agents[viz]"

生成图

你可以使用 draw_graph 函数生成智能体可视化。该函数会创建一个有向图,其中:

  • 智能体 显示为黄色方框。
  • MCP 服务 显示为灰色方框。
  • 工具 显示为绿色椭圆。
  • 任务转移 为从一个智能体到另一个智能体的有向边。

示例用法

import os

from agents import Agent, function_tool
from agents.mcp.server import MCPServerStdio
from agents.extensions.visualization import draw_graph

@function_tool
def get_weather(city: str) -> str:
    return f"The weather in {city} is sunny."

spanish_agent = Agent(
    name="Spanish agent",
    instructions="You only speak Spanish.",
)

english_agent = Agent(
    name="English agent",
    instructions="You only speak English",
)

current_dir = os.path.dirname(os.path.abspath(__file__))
samples_dir = os.path.join(current_dir, "sample_files")
mcp_server = MCPServerStdio(
    name="Filesystem Server, via npx",
    params={
        "command": "npx",
        "args": ["-y", "@modelcontextprotocol/server-filesystem", samples_dir],
    },
)

triage_agent = Agent(
    name="Triage agent",
    instructions="Handoff to the appropriate agent based on the language of the request.",
    handoffs=[spanish_agent, english_agent],
    tools=[get_weather],
    mcp_servers=[mcp_server],
)

draw_graph(triage_agent)

智能体图

这会生成一个图,直观展示 分诊智能体 的结构以及其与子智能体和工具的连接。

可视化解读

生成的图包含:

  • 一个表示入口的 起始节点__start__)。
  • 用黄色填充、以矩形表示的智能体。
  • 用绿色填充、以椭圆表示的工具。
  • 用灰色填充、以矩形表示的 MCP 服务。
  • 表示交互的有向边:
  • 实线箭头 表示智能体之间的任务转移。
  • 点线箭头 表示工具调用。
  • 虚线箭头 表示 MCP 服务调用。
  • 一个表示执行终止位置的 结束节点__end__)。

注意: 在近期版本的 agents 包(已在 v0.2.8 验证)中会渲染 MCP 服务。如果你在可视化中没有看到 MCP 方框,请升级到最新版本。

图形自定义

显示图形

默认情况下,draw_graph 会内联显示图形。若要在单独窗口中显示,请编写以下内容:

draw_graph(triage_agent).view()

保存图形

默认情况下,draw_graph 会内联显示图形。若要将其保存为文件,请指定文件名:

draw_graph(triage_agent, filename="agent_graph")

这将在工作目录中生成 agent_graph.png