当前位置: 首页 > news >正文

使用 Python 调用 OpenAI 的接口初识

使用 Python 调用 OpenAI 的接口非常简单,以下将结合实际代码示例和使用场景进行详细讲解,步骤如下:

文章目录

    • 1. 安装 OpenAI 官方库
    • 2. 准备 API Key
    • 3. 基本使用示例:调用 ChatGPT
      • **代码示例:**
      • **运行结果:**
    • 4. 高级用法:场景示例
      • **场景 1:生成内容(文章/文案/代码)**
        • **代码示例:**
        • **使用场景:**
      • **场景 2:数据分析和代码生成**
        • **代码示例:**
        • **可能的生成代码:**
        • **使用场景:**
      • **场景 3:问答机器人**
        • **代码示例:**
        • **使用场景:**
      • **场景 4:批量处理文本**
        • **代码示例:**
        • **使用场景:**
    • 5. 注意事项
    • 6. 常见问题与解决方案
      • **问题 1:如何处理 API 限制?**
      • **问题 2:如何提高请求效率?**


1. 安装 OpenAI 官方库

首先,确保安装了 OpenAI 的 Python 客户端库:

pip install openai

2. 准备 API Key

要调用 OpenAI 的接口,需要在 OpenAI 账户 中获取一个 API Key。

将你的 API Key 存储在一个变量中,比如:

OPENAI_API_KEY = "your_openai_api_key"

3. 基本使用示例:调用 ChatGPT

以下是一个简单示例,用 ChatGPT 模型完成一个对话任务:

代码示例:

import openai# 设置 API 密钥
OPENAI_API_KEY = 'your_openai_api_key'client = OpenAI(api_key=OPENAI_API_KEY,base_url='xxxxx' # 默认是https://api.openai.com/v1, 国内请求需要代理
)completion = client.chat.completions.create(# model="gpt-4o-mini",model="gpt-3.5-turbo",store=True,messages=[{"role": "system", "content": "你是一个AI助手"},{"role": "user", "content": "帮我写一个Python计算两个数之和的函数。"}]
)print(completion.choices[0].message);

运行结果:

def add_numbers(a, b):return a + b

4. 高级用法:场景示例

以下是几个常见的使用场景和实现方法:

场景 1:生成内容(文章/文案/代码)

代码示例:
response = client.chat.completions.create(model="gpt-4",messages=[{"role": "system", "content": "你是一名专业的文案编辑。"},{"role": "user", "content": "请帮我写一段产品介绍,主题是AI教育工具。"}],temperature=0.6,max_tokens=200,
)print(response['choices'][0]['message']['content'])
使用场景:
  • 用于自动生成营销文案、产品说明、或技术博客内容。

场景 2:数据分析和代码生成

代码示例:
import openai# 设置 API 密钥
OPENAI_API_KEY = 'your_openai_api_key'client = OpenAI(api_key=OPENAI_API_KEY,base_url='xxxxx' # 默认是https://api.openai.com/v1, 国内请求需要代理
)
response = client.chat.completions.create(model="gpt-4",messages=[{"role": "system", "content": "你是一名数据科学家。"},{"role": "user", "content": "请用Python写一个分析CSV文件的脚本,提取每列的平均值。"}],temperature=0.5,max_tokens=300,
)print(response['choices'][0]['message']['content'])
可能的生成代码:
import pandas as pd# 读取CSV文件
def analyze_csv(file_path):data = pd.read_csv(file_path)means = data.mean()  # 计算每列的平均值return means# 示例调用
file_path = "data.csv"
print(analyze_csv(file_path))
使用场景:
  • 自动生成常见的 Python 数据分析代码。

场景 3:问答机器人

代码示例:
import openai# 设置 API 密钥
OPENAI_API_KEY = 'your_openai_api_key'client = OpenAI(api_key=OPENAI_API_KEY,base_url='xxxxx' # 默认是https://api.openai.com/v1, 国内请求需要代理
)def chatbot_response(user_input):response = client.chat.completions.create(model="gpt-3.5-turbo",messages=[{"role": "system", "content": "你是一个智能问答机器人,可以回答各种问题。"},{"role": "user", "content": user_input}],temperature=0.7,max_tokens=150,)return response['choices'][0]['message']['content']# 用户输入
user_query = "如何用Python读取JSON文件?"
print(chatbot_response(user_query))
使用场景:
  • 创建客服机器人或在线学习助手。

场景 4:批量处理文本

代码示例:
import openai# 设置 API 密钥
OPENAI_API_KEY = 'your_openai_api_key'client = OpenAI(api_key=OPENAI_API_KEY,base_url='xxxxx' # 默认是https://api.openai.com/v1, 国内请求需要代理
)texts = ["帮我总结这段话的重点:Python是一种非常流行的编程语言,广泛用于Web开发和数据分析。","帮我翻译这句话:Hello, how are you?","生成一句关于人工智能未来发展的预测。"
]responses = []
for text in texts:response = client.chat.completions.create(model="gpt-3.5-turbo",messages=[{"role": "user", "content": text}],temperature=0.6,max_tokens=100,)responses.append(response['choices'][0]['message']['content'])print("\n".join(responses))
使用场景:
  • 文本翻译、总结、生成预测等批量任务。

5. 注意事项

  1. API Key 安全性: 不要在代码中直接暴露 API Key,可以使用环境变量:

    import os
    openai.api_key = os.getenv("OPENAI_API_KEY")
    
  2. 费用控制: OpenAI 的 API 按请求的 token 数量计费,注意控制 max_tokens 和调用频率。

  3. 模型选择: 根据任务选择合适的模型(如 gpt-3.5-turbogpt-4)。


6. 常见问题与解决方案

问题 1:如何处理 API 限制?

可以通过 openai.error 模块捕获错误并重试:

import openai
from openai.error import RateLimitError# 设置 API 密钥
OPENAI_API_KEY = 'your_openai_api_key'client = OpenAI(api_key=OPENAI_API_KEY,base_url='xxxxx' # 默认是https://api.openai.com/v1, 国内请求需要代理
)try:response = client.chat.completions.create(model="gpt-3.5-turbo",messages=[{"role": "user", "content": "你好!"}],)print(response['choices'][0]['message']['content'])
except RateLimitError:print("请求频率过高,请稍后再试。")

问题 2:如何提高请求效率?

  • 将多个任务合并到一个请求中。
  • 减少 max_tokens

通过以上方法,你可以在 Python 中灵活调用 OpenAI 的接口来实现各种场景需求。

相关文章:

使用 Python 调用 OpenAI 的接口初识

使用 Python 调用 OpenAI 的接口非常简单,以下将结合实际代码示例和使用场景进行详细讲解,步骤如下: 文章目录 1. 安装 OpenAI 官方库2. 准备 API Key3. 基本使用示例:调用 ChatGPT**代码示例:****运行结果&#xff1a…...

2025 最新flutter面试总结

目录 1.Dart是值传递还是引用传递? 2.Flutter 是单引擎还是双引擎 3. StatelessWidget 和 StatefulWidget 在 Flutter 中有什么区别? 4.简述Dart语音特性 5. Navigator 是什么?在 Flutter 中 Routes 是什么? 6、Dart 是不是…...

【MQ】RabbitMq的可靠性保证

消息队列中的可靠性主要是分为三部分: 消息不丢失:确保消息从生产者发送到消费者消息不丢失消息不重复:确保消息不被重复消费消息顺序性:确保消费的顺序性 解决方案主要有以下几部分: 消息不丢失 生产者确认机制持久…...

STM32 GPIO配置 点亮LED灯

本次是基于STM32F407ZET6做一个GPIO配置,实现点灯实验。 新建文件 LED.c、LED.h文件,将其封装到Driver文件中。 双击Driver文件将LED.c添加进来 编写头文件,这里注意需要将Driver头文件声明一下。 在LED.c、main.c里面引入头文件LED.h LED初…...

Flink把kafa数据写入Doris的N种方法及对比。

用Flink+Doris来开发实时数仓,首要解决是如何接入kafka实时流,下面是参考Doris官方文档和代码,在自己项目开发的实践中总结,包括一些容易踩坑的细节。 目录 Routine Load方法 接入kafka实时数据 踩坑的问题细节 Flink Doris Connector方法 完整示例 Routine Load方法…...

Vue - 标签中 ref 属性的使用

在 Vue 3 中&#xff0c;ref 属性用于在模板中引用 DOM 元素或组件实例。通过 ref&#xff0c;可以直接访问这些元素或组件的实例&#xff0c;从而进行更复杂的操作&#xff0c;比如获取元素的尺寸、调用组件的方法等。 基本语法&#xff1a; <template><div ref&qu…...

leetcode-不同路径问题

一个机器人位于一个 m x n 网格的左上角 &#xff08;起始点在下图中标记为 “Start” &#xff09;。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角&#xff08;在下图中标记为 “Finish” &#xff09;。 问总共有多少条不同的路径&#xff1f; 看见题目…...

MongoDB 数据库备份和恢复全攻略

在当今数据驱动的时代&#xff0c;数据库的稳定运行和数据安全至关重要。MongoDB 作为一款流行的 NoSQL 数据库&#xff0c;以其灵活的文档模型和高扩展性备受青睐。然而&#xff0c;无论数据库多么强大&#xff0c;数据丢失的风险始终存在&#xff0c;因此掌握 MongoDB 的备份…...

CentOS7使用源码安装PHP8教程整理

CentOS7使用源码安装PHP8教程整理 下载安装包解压下载的php tar源码包安装所需的一些依赖扩展库安装前的配置修改配置文件1、进入php8的安装包 配置环境变量开机自启启动服务创建软连接常见问题1、checking for icu-uc > 50.1 icu-io icu-i18n... no2、configure: error: Pa…...

Baklib助力内容中台实施的最佳实践与成功案例探索

内容概要 在当今数字化发展的背景下&#xff0c;内容中台的概念逐渐受到重视。内容中台不仅仅是一个技术平台&#xff0c;更是企业在内容管理和运营效率提升方面的重要助力。它通过整合内部资源&#xff0c;实现信息的集中管理与高效利用&#xff0c;帮助企业应对日益复杂的市…...

rocketmq-product-send方法源码分析

先看有哪些send方法 首先说红圈的 有3个红圈。归类成3种发送方式。假设前提条件&#xff0c;发送的topic&#xff0c;有3个broker&#xff0c;每个broker总共4个write队列&#xff0c;总共有12个队列。 普通发送。负载均衡12个队列。指定超时时间指定MessageQueue,发送&#…...

python flask中使用or查询和and查询,还有同时使用or、and的情况

在 Flask 中处理数据库查询时&#xff0c;通常会结合使用 ORM 工具&#xff0c;例如 SQLAlchemy。以下是 or 查询、and 查询以及两者同时使用的示例。 文章目录 基础准备1. 使用 or_ 查询2. 使用 and_ 查询3. 同时使用 or_ 和 and_4. 更加复杂的嵌套查询 基础准备 假设有一个…...

【第一天】零基础入门刷题Python-算法篇-数据结构与算法的介绍(持续更新)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、Python数据结构与算法的详细介绍1.基本概念2.Python中的数据结构1. 列表&#xff08;List&#xff09;2. 元组&#xff08;Tuple&#xff09;3. 字典&#…...

租房管理系统实现智能化租赁提升用户体验与运营效率

内容概要 在当今快速发展的租赁市场中&#xff0c;租房管理系统的智能化转型显得尤为重要。它不仅帮助房东和租客之间建立更高效的沟通桥梁&#xff0c;还优化了整个租赁流程。通过智能化技术&#xff0c;这套系统能够自动处理资产管理、合同签署、财务管理等所有关键环节。这…...

python3+TensorFlow 2.x(四)反向传播

目录 反向传播算法 反向传播算法基本步骤&#xff1a; 反向中的参数变化 总结 反向传播算法 反向传播算法&#xff08;Backpropagation&#xff09;是训练人工神经网络时使用的一个重要算法&#xff0c;它是通过计算梯度并优化神经网络的权重来最小化误差。反向传播算法的核…...

Flutter 使用 flutter_inappwebview 加载 App 本地 HTML 文件

在 Flutter 开发中&#xff0c;加载本地 HTML 文件是一个常见的需求&#xff0c;尤其是在需要展示离线内容或自定义页面时。flutter_inappwebview 是一个功能强大的插件&#xff0c;支持加载本地文件和网络资源。本文将详细介绍如何使用 flutter_inappwebview 加载 App 本地 HT…...

Word常见问题:嵌入图片无法显示完整

场景&#xff1a;在Word中&#xff0c;嵌入式图片显示不全&#xff0c;一部分图片在文字下方。如&#xff1a; 问题原因&#xff1a;因段落行距导致 方法一 快捷方式 选中图片&#xff0c;通过"ctrl1"快捷调整为1倍行距 方法二 通过工具栏调整 选中图片&#xff0…...

为AI聊天工具添加一个知识系统 之68 详细设计 之9 三种中台和时间度量 之1

本文要点 要点 在维度0上 被分离出来 的业务中台 需求、技术中台要求、和数据中台请求 &#xff08;分别在时间层/空间层/时空层上 对应一个不同种类槽的容器&#xff0c;分别表示业务特征Feature[3]/技术方面Aspect[3]/数据流Fluent[3]&#xff09; 在维度1~3的运动过程中 从…...

On to OpenGL and 3D computer graphics

2. On to OpenGL and 3D computer graphics 声明&#xff1a;该代码来自&#xff1a;Computer Graphics Through OpenGL From Theory to Experiments&#xff0c;仅用作学习参考 2.1 First Program Square.cpp完整代码 /// // square.cpp // // OpenGL program to draw a squ…...

从曾国藩的经历看如何打破成长中的瓶颈

《曾国藩传》是一部充满智慧与人生哲理的传记&#xff0c;而曾国藩本人更是一个从“最笨”到“最智慧”的奇人。看他的成长与蜕变&#xff0c;不仅能感受到他如何超越自己的局限&#xff0c;也能从中获得关于人性、社会和历史的重要启示。曾国藩的一生让人深思&#xff0c;正是…...

Day131 | 灵神 | 回溯算法 | 子集型 子集

Day131 | 灵神 | 回溯算法 | 子集型 子集 78.子集 78. 子集 - 力扣&#xff08;LeetCode&#xff09; 思路&#xff1a; 笔者写过很多次这道题了&#xff0c;不想写题解了&#xff0c;大家看灵神讲解吧 回溯算法套路①子集型回溯【基础算法精讲 14】_哔哩哔哩_bilibili 完…...

从深圳崛起的“机器之眼”:赴港乐动机器人的万亿赛道赶考路

进入2025年以来&#xff0c;尽管围绕人形机器人、具身智能等机器人赛道的质疑声不断&#xff0c;但全球市场热度依然高涨&#xff0c;入局者持续增加。 以国内市场为例&#xff0c;天眼查专业版数据显示&#xff0c;截至5月底&#xff0c;我国现存在业、存续状态的机器人相关企…...

关于iview组件中使用 table , 绑定序号分页后序号从1开始的解决方案

问题描述&#xff1a;iview使用table 中type: "index",分页之后 &#xff0c;索引还是从1开始&#xff0c;试过绑定后台返回数据的id, 这种方法可行&#xff0c;就是后台返回数据的每个页面id都不完全是按照从1开始的升序&#xff0c;因此百度了下&#xff0c;找到了…...

ESP32读取DHT11温湿度数据

芯片&#xff1a;ESP32 环境&#xff1a;Arduino 一、安装DHT11传感器库 红框的库&#xff0c;别安装错了 二、代码 注意&#xff0c;DATA口要连接在D15上 #include "DHT.h" // 包含DHT库#define DHTPIN 15 // 定义DHT11数据引脚连接到ESP32的GPIO15 #define D…...

渲染学进阶内容——模型

最近在写模组的时候发现渲染器里面离不开模型的定义,在渲染的第二篇文章中简单的讲解了一下关于模型部分的内容,其实不管是方块还是方块实体,都离不开模型的内容 🧱 一、CubeListBuilder 功能解析 CubeListBuilder 是 Minecraft Java 版模型系统的核心构建器,用于动态创…...

【单片机期末】单片机系统设计

主要内容&#xff1a;系统状态机&#xff0c;系统时基&#xff0c;系统需求分析&#xff0c;系统构建&#xff0c;系统状态流图 一、题目要求 二、绘制系统状态流图 题目&#xff1a;根据上述描述绘制系统状态流图&#xff0c;注明状态转移条件及方向。 三、利用定时器产生时…...

三体问题详解

从物理学角度&#xff0c;三体问题之所以不稳定&#xff0c;是因为三个天体在万有引力作用下相互作用&#xff0c;形成一个非线性耦合系统。我们可以从牛顿经典力学出发&#xff0c;列出具体的运动方程&#xff0c;并说明为何这个系统本质上是混沌的&#xff0c;无法得到一般解…...

大学生职业发展与就业创业指导教学评价

这里是引用 作为软工2203/2204班的学生&#xff0c;我们非常感谢您在《大学生职业发展与就业创业指导》课程中的悉心教导。这门课程对我们即将面临实习和就业的工科学生来说至关重要&#xff0c;而您认真负责的教学态度&#xff0c;让课程的每一部分都充满了实用价值。 尤其让我…...

蓝桥杯 冶炼金属

原题目链接 &#x1f527; 冶炼金属转换率推测题解 &#x1f4dc; 原题描述 小蓝有一个神奇的炉子用于将普通金属 O O O 冶炼成为一种特殊金属 X X X。这个炉子有一个属性叫转换率 V V V&#xff0c;是一个正整数&#xff0c;表示每 V V V 个普通金属 O O O 可以冶炼出 …...

SQL慢可能是触发了ring buffer

简介 最近在进行 postgresql 性能排查的时候,发现 PG 在某一个时间并行执行的 SQL 变得特别慢。最后通过监控监观察到并行发起得时间 buffers_alloc 就急速上升,且低水位伴随在整个慢 SQL,一直是 buferIO 的等待事件,此时也没有其他会话的争抢。SQL 虽然不是高效 SQL ,但…...