练习项目:多智能体天气查询系统

练习项目:多智能体天气查询系统

一、项目背景

1.0 技术栈

技术 版本 说明
Python 3.12+ 编程语言
uv 0.10+ Python 包管理器(虚拟环境)
openai-agents 0.12.5 OpenAI Agents SDK,多智能体框架
openai - OpenAI API 客户端(兼容 DeepSeek)
pydantic - 数据验证和设置管理
python-dotenv 1.2.2 环境变量管理
DeepSeek API - LLM 提供商(R1 推理模型、V3 对话模型)

虚拟环境管理(uv):

bash 复制代码
# 创建虚拟环境
uv venv

# 安装依赖
uv pip install openai-agents python-dotenv pydantic

# 运行脚本
uv run python xxx.py

# 运行模块
uv run python -m module_name

API 配置(.env):

bash 复制代码
API_KEY=your-api-key
BASE_URL=https://api.qnaigc.com/v1  # 或其他兼容 API 地址

系统架构

复制代码
用户输入: "北京今天天气怎么样?"
       │
       ▼
┌─────────────────────────────────────────────────────────────┐
│  规划智能体【系统管理器】(DeepSeek-R1)                      │
│  分析用户意图、提取城市名、确定调用策略                       │
└─────────────────────────────────────────────────────────────┘
       │
       ▼
┌─────────────────────────────────────────────────────────────┐
│  分配智能体【服务管理器】(DeepSeek-V3)                       │
│  调用天气查询工具                                            │
└─────────────────────────────────────────────────────────────┘
       │
       ▼
┌─────────────────────────────────────────────────────────────┐
│  天气查询工具                                               │
│  返回指定城市的天气信息                                       │
└─────────────────────────────────────────────────────────────┘
       │
       ▼
┌─────────────────────────────────────────────────────────────┐
│  格式化智能体【输出适配器】                                  │
│  根据用户语言格式化输出(中文/英文)                          │
└─────────────────────────────────────────────────────────────┘
       │
       ▼
  返回格式化后的天气信息

项目结构要求

复制代码
weather_agent/
├── __init__.py
├── agents/
│   ├── __init__.py
│   ├── planner.py          # 规划智能体 (deepseek-r1)
│   ├── dispatcher.py       # 分配智能体 (deepseek-v3)
│   └── formatters.py       # 格式化智能体
├── tools/
│   ├── __init__.py
│   └── weather_tools.py    # 天气查询工具
├── workflow.py             # 工作流(支持流式输出)
├── models.py               # 数据模型
└── demo.py                # 演示入口

技术要求

  1. 模型选择

    • 规划智能体使用 deepseek-r1
    • 其他智能体使用 deepseek-v3
  2. 环境配置

    • 使用 .env 文件配置 API_KEY 和 BASE_URL
  3. 流式输出

    • 参考 knowledge_agent/workflow.py 实现流式输出
  4. 工具实现

    • 使用 @function_tool 装饰器
    • 实现天气查询功能(可使用模拟数据)
  5. 多语言支持

    • 中文查询返回中文天气信息
    • 英文查询返回英文天气信息

功能要求

  1. 城市识别:从用户输入中提取城市名称
  2. 天气查询:查询指定城市的天气
  3. 多语言输出:根据用户语言返回对应格式
  4. 错误处理:对无效城市给出友好提示

验收标准

  1. 运行 python -m weather_agent.demo
  2. 输入测试:
    • "北京今天天气怎么样?" → 返回中文天气
    • "How's the weather in Tokyo?" → 返回英文天气
  3. 实现流式输出,实时显示各阶段进度

扩展挑战(可选)

  1. 支持多天预报查询
  2. 支持温度单位切换(摄氏度/华氏度)
  3. 添加更多天气信息(湿度、风力、空气质量等)
  4. 使用真实的天气 API(如 OpenWeatherMap)

参考资料

  • multi_agent_coordinator/ - 完整参考实现
  • knowledge_agent/workflow.py - 流式输出参考
  • .env - 环境配置参考
相关推荐
科技小花4 小时前
全球化深水区,数据治理成为企业出海 “核心竞争力”
大数据·数据库·人工智能·数据治理·数据中台·全球化
zhuiyisuifeng5 小时前
2026前瞻:GPTimage2镜像官网或将颠覆视觉创作
人工智能·gpt
徐健峰5 小时前
GPT-image-2 热门玩法实战(一):AI 看手相 — 一张手掌照片生成专业手相分析图
人工智能·gpt
weixin_370976355 小时前
AI的终极赛跑:进入AGI,还是泡沫破灭?
大数据·人工智能·agi
Slow菜鸟5 小时前
AI学习篇(五) | awesome-design-md 使用说明
人工智能·学习
冬奇Lab6 小时前
RAG 系列(五):Embedding 模型——语义理解的核心
人工智能·llm·aigc
深小乐6 小时前
AI 周刊【2026.04.27-05.03】:Anthropic 9000亿美元估值、英伟达死磕智能体、中央重磅定调AI
人工智能
码点滴6 小时前
什么时候用 DeepSeek V4,而不是 GPT-5/Claude/Gemini?
人工智能·gpt·架构·大模型·deepseek
狐狐生风6 小时前
LangChain 向量存储:Chroma、FAISS
人工智能·python·学习·langchain·faiss·agentai
波动几何6 小时前
CDA架构代码工坊技能cda-code-lab
人工智能