快速入门
项目和虚拟环境的创建
你只需执行一次。
虚拟环境的激活
每次启动新的终端会话时都要执行此操作。
在 macOS 或 Linux 上:
在 Windows 上:
Agents SDK 的安装
OpenAI API 密钥的设置
如果你还没有密钥,请按照这些说明创建 OpenAI API 密钥。
这些命令会为当前终端会话设置密钥。
在 macOS 或 Linux 上:
在 Windows PowerShell 上:
在 Windows 命令提示符上:
第一个智能体的创建
智能体通过 instructions、名称以及可选配置(例如特定模型)来定义。
from agents import Agent
agent = Agent(
name="History Tutor",
instructions="You answer history questions clearly and concisely.",
)
第一个智能体的运行
使用 Runner 执行智能体,并获取返回的 RunResult。
import asyncio
from agents import Agent, Runner
agent = Agent(
name="History Tutor",
instructions="You answer history questions clearly and concisely.",
)
async def main():
result = await Runner.run(agent, "When did the Roman Empire fall?")
print(result.final_output)
if __name__ == "__main__":
asyncio.run(main())
对于第二轮,你可以将 result.to_input_list() 传回 Runner.run(...),附加一个 session,或使用 conversation_id / previous_response_id 复用 OpenAI 服务管理的状态。运行智能体指南对这些方法进行了比较。
可使用以下经验法则:
| 如果你想要... | 从以下方式开始... |
|---|---|
| 完全手动控制且与提供商无关的历史记录 | result.to_input_list() |
| 由 SDK 为你加载和保存历史记录 | session=... |
| OpenAI 管理的服务端延续 | previous_response_id 或 conversation_id |
有关取舍和确切行为,请参阅运行智能体。
当任务主要依赖提示词、工具和对话状态时,请使用普通的 Agent 加 Runner。如果智能体应在隔离工作区中检查或修改真实文件,请转到 Sandbox agents 快速入门。
为智能体提供工具
你可以为智能体提供工具来查找信息或执行操作。
import asyncio
from agents import Agent, Runner, function_tool
@function_tool
def history_fun_fact() -> str:
"""Return a short history fact."""
return "Sharks are older than trees."
agent = Agent(
name="History Tutor",
instructions="Answer history questions clearly. Use history_fun_fact when it helps.",
tools=[history_fun_fact],
)
async def main():
result = await Runner.run(
agent,
"Tell me something surprising about ancient life on Earth.",
)
print(result.final_output)
if __name__ == "__main__":
asyncio.run(main())
添加更多智能体
在选择多智能体模式之前,先决定谁应拥有最终答案:
- 任务转移:专家接管本轮中该部分的对话。
- Agents as tools:编排器保持控制,并将专家作为工具调用。
本快速入门继续使用任务转移,因为它是最简短的第一个示例。有关管理器风格的模式,请参阅智能体编排和工具:agents as tools。
可以用同样的方式定义其他智能体。handoff_description 会为路由智能体提供有关何时委派的额外上下文。
from agents import Agent
history_tutor_agent = Agent(
name="History Tutor",
handoff_description="Specialist agent for historical questions",
instructions="You answer history questions clearly and concisely.",
)
math_tutor_agent = Agent(
name="Math Tutor",
handoff_description="Specialist agent for math questions",
instructions="You explain math step by step and include worked examples.",
)
任务转移的定义
在智能体上,你可以定义一组可选的传出任务转移选项,供其在解决任务时选择。
triage_agent = Agent(
name="Triage Agent",
instructions="Route each homework question to the right specialist.",
handoffs=[history_tutor_agent, math_tutor_agent],
)
智能体编排的运行
运行器会处理各个智能体的执行、任何任务转移以及任何工具调用。
import asyncio
from agents import Runner
async def main():
result = await Runner.run(
triage_agent,
"Who was the first president of the United States?",
)
print(result.final_output)
print(f"Answered by: {result.last_agent.name}")
if __name__ == "__main__":
asyncio.run(main())
参考代码示例
该仓库包含相同核心模式的完整脚本:
examples/basic/hello_world.py用于首次运行。examples/basic/tools.py用于工具调用。examples/agent_patterns/routing.py用于多智能体路由。
查看追踪
要回顾智能体运行期间发生的情况,请前往 OpenAI Dashboard 中的 Trace viewer查看智能体运行的追踪。
后续步骤
学习如何构建更复杂的智能体式流程: