基于Swarm的大模型应用:一个天气助手

本次实践主要是基于open Ai 的swarm与deepSeek模型,定制一个大模型智能体,帮助我们认识swam(多智能体写作文)以及如何使用;

1 deekSeeK

注册:DeepSeek

申请自己的apiKey:******;

注意:model="deepseek-chat", 这一个参数我们需要在OpenAi 中配置;

复制代码
from openai import OpenAI

client = OpenAI(api_key="<DeepSeek API Key>", base_url="https://api.deepseek.com")

response = client.chat.completions.create(
    model="deepseek-chat",
    messages=[
        {"role": "system", "content": "You are a helpful assistant"},
        {"role": "user", "content": "Hello"},
    ],
    stream=False
)

print(response.choices[0].message.content)

2 python环境

注意:安装swarm需要依赖于3.10.0版本;

pip install git+https://github.com/openai/swarm.git

3 代码

swarm:是一个集群

Agent:是一个具体的工作流;

python 复制代码
import requests
import os

from swarm import Swarm, Agent
import openai



def get_weather(latitude: float, longitude: float) -> str:
    """
    使用Open-Meteo API获取给定坐标的当前天气。

    参数:
    latitude (float): 纬度
    longitude (float): 经度

    返回:
    str: 包含当前温度和风速的天气信息JSON字符串
    """
    url = f"https://api.open-meteo.com/v1/forecast?latitude={latitude}&longitude={longitude}&current=temperature_2m,wind_speed_10m"
    
    response = requests.get(url)
    if response.status_code == 200:
        data = response.json()
        current = data['current']
        return str(current)  # 返回JSON字符串
    else:
        return '{"error": "无法获取天气数据"}'

def get_coordinates(location: str) -> str:
    """
    获取给定位置名称的坐标。

    参数:
    location (str): 位置名称

    返回:
    str: 包含纬度和经度的JSON字符串
    """
    #print('11111111')
    coordinates = {
        "纽约": (40.7128, -74.0060),
        "伦敦": (51.5074, -0.1278),
        "东京": (35.6762, 139.6503),
        "巴黎": (48.8566, 2.3522),
        "柏林": (52.5200, 13.4050)
    }
    lat, lon = coordinates.get(location.lower(), (0, 0))
    print(f"获取当前的时间:{location}, {lat}")
    return f'{{"latitude": {lat}, "longitude": {lon}}}'

from openai import OpenAI
# 自己api_key

open_ai = OpenAI(api_key="*****"
                 ,base_url='https://api.deepseek.com/')

client = Swarm(client=open_ai)

weather_agent = Agent(
    name="天气助手",
    instructions="""
    你是一个有帮助的天气助手。当被问到特定位置的天气时:
    1. 使用get_coordinates函数获取该位置的坐标。
    2. 使用get_weather函数获取天气数据。
    3. 解析返回的JSON数据,提供一个友好的回复,包含天气信息。
    如果无法识别该位置,礼貌地通知用户并建议他们尝试一个主要城市。
    """,
    model='deepseek-chat', # 这个参数很重要,不然总是报错
    functions=[get_coordinates, get_weather]
)

def run_weather_query(query: str) -> str:
    """
    运行天气查询并返回结果。

    参数:
    query (str): 用户的天气查询

    返回:
    str: Agent的响应
    """
    messages = [{"role": "user", "content": query}]
    #print("11111222222")
    response = client.run(agent=weather_agent, messages=messages)
    return response.messages[-1]["content"]

# 使用示例
print(run_weather_query("纽约的天气怎么样?"))
相关推荐
财迅通Ai7 小时前
百通能源:2026年一季度营收稳步增长,资产结构持续优化
大数据·人工智能·能源·百通能源
风落无尘7 小时前
第二章《概率与生存》完整学习资料
人工智能·矩阵·概率论
迪娜学姐7 小时前
ChatGPT image 2 科研绘图实测分享
人工智能·chatgpt
m0_609160497 小时前
MongoDB中什么是Hashed Shard Key的哈希冲突_哈希函数的分布均匀性分析
jvm·数据库·python
Ulyanov7 小时前
《现代 Python 桌面应用架构实战:PySide6 + QML 从入门到工程化》 开发环境搭建与工具链极简主义 —— 拒绝臃肿,构建工业级基座
开发语言·python·qt·ui·架构·系统仿真
千匠网络7 小时前
数智全链赋能,千匠网络钢铁能源供应链平台解决方案
大数据·人工智能
小超同学你好7 小时前
论文精读:《Indirect Prompt Injection》—— 当AI助手成为别人的“提线木偶“
人工智能·prompt
逻辑驱动的ken7 小时前
Java高频面试场景题19
java·开发语言·面试·职场和发展·求职招聘
wuxinyan1237 小时前
大模型学习之路03:提示工程从入门到精通(第三篇)
人工智能·python·学习
无心水7 小时前
【Hermes:Skill系统深度】22、资产保值时代:OpenClaw Skill → Hermes 无缝迁移完整指南
人工智能·ai·openclaw·养龙虾·hermes·养马·honcho