使用 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. 注意事项
-
API Key 安全性: 不要在代码中直接暴露 API Key,可以使用环境变量:
import os openai.api_key = os.getenv("OPENAI_API_KEY") -
费用控制: OpenAI 的 API 按请求的 token 数量计费,注意控制
max_tokens和调用频率。 -
模型选择: 根据任务选择合适的模型(如
gpt-3.5-turbo或gpt-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**代码示例:****运行结果:…...
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 中,ref 属性用于在模板中引用 DOM 元素或组件实例。通过 ref,可以直接访问这些元素或组件的实例,从而进行更复杂的操作,比如获取元素的尺寸、调用组件的方法等。 基本语法: <template><div ref&qu…...
leetcode-不同路径问题
一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish” )。 问总共有多少条不同的路径? 看见题目…...
MongoDB 数据库备份和恢复全攻略
在当今数据驱动的时代,数据库的稳定运行和数据安全至关重要。MongoDB 作为一款流行的 NoSQL 数据库,以其灵活的文档模型和高扩展性备受青睐。然而,无论数据库多么强大,数据丢失的风险始终存在,因此掌握 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助力内容中台实施的最佳实践与成功案例探索
内容概要 在当今数字化发展的背景下,内容中台的概念逐渐受到重视。内容中台不仅仅是一个技术平台,更是企业在内容管理和运营效率提升方面的重要助力。它通过整合内部资源,实现信息的集中管理与高效利用,帮助企业应对日益复杂的市…...
rocketmq-product-send方法源码分析
先看有哪些send方法 首先说红圈的 有3个红圈。归类成3种发送方式。假设前提条件,发送的topic,有3个broker,每个broker总共4个write队列,总共有12个队列。 普通发送。负载均衡12个队列。指定超时时间指定MessageQueue,发送&#…...
python flask中使用or查询和and查询,还有同时使用or、and的情况
在 Flask 中处理数据库查询时,通常会结合使用 ORM 工具,例如 SQLAlchemy。以下是 or 查询、and 查询以及两者同时使用的示例。 文章目录 基础准备1. 使用 or_ 查询2. 使用 and_ 查询3. 同时使用 or_ 和 and_4. 更加复杂的嵌套查询 基础准备 假设有一个…...
【第一天】零基础入门刷题Python-算法篇-数据结构与算法的介绍(持续更新)
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、Python数据结构与算法的详细介绍1.基本概念2.Python中的数据结构1. 列表(List)2. 元组(Tuple)3. 字典&#…...
租房管理系统实现智能化租赁提升用户体验与运营效率
内容概要 在当今快速发展的租赁市场中,租房管理系统的智能化转型显得尤为重要。它不仅帮助房东和租客之间建立更高效的沟通桥梁,还优化了整个租赁流程。通过智能化技术,这套系统能够自动处理资产管理、合同签署、财务管理等所有关键环节。这…...
python3+TensorFlow 2.x(四)反向传播
目录 反向传播算法 反向传播算法基本步骤: 反向中的参数变化 总结 反向传播算法 反向传播算法(Backpropagation)是训练人工神经网络时使用的一个重要算法,它是通过计算梯度并优化神经网络的权重来最小化误差。反向传播算法的核…...
Flutter 使用 flutter_inappwebview 加载 App 本地 HTML 文件
在 Flutter 开发中,加载本地 HTML 文件是一个常见的需求,尤其是在需要展示离线内容或自定义页面时。flutter_inappwebview 是一个功能强大的插件,支持加载本地文件和网络资源。本文将详细介绍如何使用 flutter_inappwebview 加载 App 本地 HT…...
Word常见问题:嵌入图片无法显示完整
场景:在Word中,嵌入式图片显示不全,一部分图片在文字下方。如: 问题原因:因段落行距导致 方法一 快捷方式 选中图片,通过"ctrl1"快捷调整为1倍行距 方法二 通过工具栏调整 选中图片࿰…...
为AI聊天工具添加一个知识系统 之68 详细设计 之9 三种中台和时间度量 之1
本文要点 要点 在维度0上 被分离出来 的业务中台 需求、技术中台要求、和数据中台请求 (分别在时间层/空间层/时空层上 对应一个不同种类槽的容器,分别表示业务特征Feature[3]/技术方面Aspect[3]/数据流Fluent[3]) 在维度1~3的运动过程中 从…...
On to OpenGL and 3D computer graphics
2. On to OpenGL and 3D computer graphics 声明:该代码来自:Computer Graphics Through OpenGL From Theory to Experiments,仅用作学习参考 2.1 First Program Square.cpp完整代码 /// // square.cpp // // OpenGL program to draw a squ…...
从曾国藩的经历看如何打破成长中的瓶颈
《曾国藩传》是一部充满智慧与人生哲理的传记,而曾国藩本人更是一个从“最笨”到“最智慧”的奇人。看他的成长与蜕变,不仅能感受到他如何超越自己的局限,也能从中获得关于人性、社会和历史的重要启示。曾国藩的一生让人深思,正是…...
Vim 调用外部命令学习笔记
Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...
Python|GIF 解析与构建(5):手搓截屏和帧率控制
目录 Python|GIF 解析与构建(5):手搓截屏和帧率控制 一、引言 二、技术实现:手搓截屏模块 2.1 核心原理 2.2 代码解析:ScreenshotData类 2.2.1 截图函数:capture_screen 三、技术实现&…...
变量 varablie 声明- Rust 变量 let mut 声明与 C/C++ 变量声明对比分析
一、变量声明设计:let 与 mut 的哲学解析 Rust 采用 let 声明变量并通过 mut 显式标记可变性,这种设计体现了语言的核心哲学。以下是深度解析: 1.1 设计理念剖析 安全优先原则:默认不可变强制开发者明确声明意图 let x 5; …...
Leetcode 3577. Count the Number of Computer Unlocking Permutations
Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接:3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯,要想要能够将所有的电脑解锁&#x…...
全球首个30米分辨率湿地数据集(2000—2022)
数据简介 今天我们分享的数据是全球30米分辨率湿地数据集,包含8种湿地亚类,该数据以0.5X0.5的瓦片存储,我们整理了所有属于中国的瓦片名称与其对应省份,方便大家研究使用。 该数据集作为全球首个30米分辨率、覆盖2000–2022年时间…...
vue3 字体颜色设置的多种方式
在Vue 3中设置字体颜色可以通过多种方式实现,这取决于你是想在组件内部直接设置,还是在CSS/SCSS/LESS等样式文件中定义。以下是几种常见的方法: 1. 内联样式 你可以直接在模板中使用style绑定来设置字体颜色。 <template><div :s…...
VTK如何让部分单位不可见
最近遇到一个需求,需要让一个vtkDataSet中的部分单元不可见,查阅了一些资料大概有以下几种方式 1.通过颜色映射表来进行,是最正规的做法 vtkNew<vtkLookupTable> lut; //值为0不显示,主要是最后一个参数,透明度…...
第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词
Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵,其中每行,每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid,其中有多少个 3 3 的 “幻方” 子矩阵&am…...
OPENCV形态学基础之二腐蚀
一.腐蚀的原理 (图1) 数学表达式:dst(x,y) erode(src(x,y)) min(x,y)src(xx,yy) 腐蚀也是图像形态学的基本功能之一,腐蚀跟膨胀属于反向操作,膨胀是把图像图像变大,而腐蚀就是把图像变小。腐蚀后的图像变小变暗淡。 腐蚀…...
Java + Spring Boot + Mybatis 实现批量插入
在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法:使用 MyBatis 的 <foreach> 标签和批处理模式(ExecutorType.BATCH)。 方法一:使用 XML 的 <foreach> 标签ÿ…...
