Assistant API的原理及应用


🧠 什么是 Assistants API?

📅 **发布日期:**2023年11月6日,OpenAI在开发者大会上发布了 Assistants API ------ 一款面向开发者的工具,用于在应用中构建 AI 助手。

✅ 它可以做什么?

Assistants API 允许开发者构建智能助手,这些助手可通过:

  • instructions(指令):设定助手行为;
  • models(模型):指定使用的 GPT 模型;
  • tools(工具):调用代码解释器、知识库检索等功能;
  • knowledge(知识):接入外部知识库提升回答能力。

🔧 当前支持的工具类型:

工具名 中文含义 功能简介
Code Interpreter 代码解释器 运行代码、执行计算任务
Retrieval 检索 与知识库集成,支持 RAG
Function Calling 函数调用 调用自定义 API 或业务逻辑

🤝 Assistants API vs GPTs 的区别与联系

对比维度 Assistants API GPTs
创建方式 编写代码集成 无代码配置(ChatGPT界面)
部署位置 集成进自定义产品中 使用 ChatGPT Web
UI 体验 需开发者自定义 UI ChatGPT 原生 UI
分享功能 无内置 内置分享 GPTs

共同点:

  • 都基于 OpenAI 的 GPT 技术;
  • 都支持指令、知识库等定制化;
  • 都用于提供个性化智能助手体验。

⚙️ Assistant API 的原理与核心流程

🌟 Assistants API 核心概念图解:

概念名 含义说明
Assistant 定义好的 AI 助手,绑定模型、指令、工具等
Thread 用户与助手的对话历史上下文
Message 单条对话信息,可以是文字、图片等
Run 发起一次助手任务执行
Run Step 助手执行任务的详细过程(是否调用工具等)

💡 整体执行流程如下:

  1. 创建 Assistant:设置指令、选择模型,绑定工具和文件;
  2. 创建 Thread:创建对话线程;
  3. 添加 Message:将用户问题添加进线程;
  4. 执行 Run:触发一次对话逻辑,模型生成回答;
  5. 读取结果:助手将在 Thread 中附加响应。

⚠️ 当前为 beta 阶段,部分功能可能不稳定或在持续迭代中。


🛠️ 实践项目:构建一个"水果收银助手"

✨ 项目背景

使用 MiniMax 开放平台 模拟 OpenAI Assistants API,实现一个能帮我们计算水果利润的助手。

📂 文件准备:我们先创建 fruit_price.txt,内容如下:

复制代码
香蕉:成本2元/斤,售价3元/斤  
橘子:成本1.5元/斤,售价2.5元/斤  
苹果:成本3元/斤,售价3.5元/斤  
芒果:成本5元/斤,售价6元/斤  
葡萄:成本2元/斤,售价4元/斤

✅ 实现流程详解


📦 3.1 导入工具包

python 复制代码
import requests    # 用于发送 HTTP 请求
import json        # JSON 数据处理
import time, os
from dotenv import load_dotenv, find_dotenv  # 读取 .env 文件中的环境变量

⚙️ 3.2 配置环境变量

python 复制代码
_ = load_dotenv(find_dotenv())
GroupId = os.environ['GroupId']
API_KEY = os.environ['API_KEY']

headers = {
    'Authorization': f'Bearer {API_KEY}',
    'Content-Type': 'application/json'
}

headers_retrieval = {
    'Authorization': f'Bearer {API_KEY}',
    'authority': 'api.minimax.chat',
}

📤 3.3 上传文件

python 复制代码
def create_file():
    url = f"https://api.minimax.chat/v1/files/upload?GroupId={GroupId}"
    files = {'file': open('./fruit_price.txt', 'rb')}
    data = {'purpose': 'assistants'}
    response = requests.post(url, headers=headers_retrieval, data=data, files=files)
    return response.json()

🤖 3.4 创建助手(Assistant)

python 复制代码
def create_assistant(file_id):
    url = f"https://api.minimax.chat/v1/assistants/create?GroupId={GroupId}"
    payload = json.dumps({
        "model": "abab5.5-chat",
        "name": "水果店财务助手",
        "description": "用于统计营业额和利润",
        "instructions": "根据水果销量、成本和售价计算利润",
        "file_ids": [str(file_id)],
        "tools": [{"type": "retrieval"}]
    })
    response = requests.post(url, headers=headers, data=payload)
    return response.json()

📌 常用模型版本:abab5.5-chat, abab6.5-chat, abab6.5s-chat, 支持多种工具组合。


🧵 3.5 创建线程

python 复制代码
def create_thread():
    url = f"https://api.minimax.chat/v1/threads/create?GroupId={GroupId}"
    response = requests.post(url, headers=headers)
    return response.json()

💬 3.6 添加消息到线程

python 复制代码
def add_message_to_thread(thread_id):
    url = f"https://api.minimax.chat/v1/threads/messages/add?GroupId={GroupId}"
    payload = json.dumps({
        "thread_id": thread_id,
        "role": "user",
        "content": "我卖了2斤葡萄,3斤半的香蕉,2斤苹果,计算下总成本和总收入,给出具体的计算过程"
    })
    response = requests.post(url, headers=headers, data=payload)
    return response.json()

▶️ 3.7 运行助手

python 复制代码
def run_thread_with_assistant(thread_id, assistant_id):
    time.sleep(200)  # 等待 Assistant 向量化文件完成
    url = f"https://api.minimax.chat/v1/threads/run/create?GroupId={GroupId}"
    payload = json.dumps({
        "thread_id": thread_id,
        "assistant_id": assistant_id
    })
    response = requests.post(url, headers=headers, data=payload)
    return response.json()

🔄 3.8 查看运行状态

python 复制代码
def check_thread_run_status(thread_id, run_id):
    url = f"https://api.minimax.chat/v1/threads/run/retrieve?GroupId={GroupId}"
    payload = json.dumps({
        "thread_id": str(thread_id),
        "run_id": str(run_id)
    })
    completed = False
    while not completed:
        response = requests.request("GET", url, headers=headers, data=payload)
        if response.status_code == 200:
            status = response.json().get('status', '')
            print(f"Status: {status}")
            if status == 'completed':
                completed = True
            else:
                time.sleep(2)
        else:
            print(f"Error: {response.status_code}")
            break
    return completed

📥 3.9 获取助手回复

python 复制代码
def get_thread_messages(thread_id):
    url = f"https://api.minimax.chat/v1/threads/messages/list?GroupId={GroupId}"
    payload = json.dumps({"thread_id": thread_id})
    response = requests.get(url, headers=headers, data=payload)
    return response.json()

✅ 总结

通过 MiniMax 平台模拟使用 OpenAI 的 Assistants API,可以体验构建专属 AI 助手的流程,特别适合教学、企业内训与原型系统开发。下一步可以加入函数调用、外部 API 接入等扩展功能,增强助手的实用性与智能度。

相关推荐
非著名架构师11 分钟前
物流算法的“高阶变量”:高精度AI气象如何为智能供应链注入“天气理解力”,实现动态成本与风险最优?
人工智能·疾风气象大模型·高精度天气预报数据·galeweather.cn·高精度气象·风电光伏功率预测
后端小肥肠11 分钟前
Coze编程首测:我用大白话搭了个“AI漫剧流水线”,太离谱了!
人工智能·aigc·coze
倪偲00112 分钟前
livox/CustomMsg消息从ROS1 bag转换成ROS2
人工智能·机器人·自动驾驶
IT知识分享12 分钟前
中科天玑全要素AI舆情系统功能、架构解析
人工智能·语言模型·架构
AI营销资讯站28 分钟前
AI营销内容生产新趋势:原圈科技引领企业全球化内容智能升级
人工智能·科技
dagouaofei31 分钟前
AI自动生成PPT工具横评,真实使用感受分享
人工智能·python·powerpoint
JoannaJuanCV40 分钟前
自动驾驶—CARLA仿真(19)automatic_control demo
人工智能·机器学习·自动驾驶
热爱生活的五柒43 分钟前
PolSAR Image Registration——极化合成孔径雷达(PolSAR)图像配准
人工智能·计算机视觉·sar
qq_2337727144 分钟前
**给复杂机器“装上行车记录仪”:一篇量子论文如何照亮AI时代的信任之路**
人工智能
美林数据Tempodata44 分钟前
案例分享|西安财经大学打造全覆盖、全链条人工智能通识教育培养体系
人工智能