Python OpenAI 库开发指南:从入门到实战精通
在人工智能(AI)领域,OpenAI无疑是全球最受瞩目的机构之一。它推出的GPT系列模型、DALL·E等创新技术,正在深刻改变各行各业。作为Python开发者,我们该如何快速上手并高效利用OpenAI的API,成为了提升个人竞争力的关键。
本文将带你从零开始,深入解析Python语言中的openAI库,助你掌握AI开发的核心工具,成为AI领域的专家。
一、什么是openAI库?它能为开发者带来什么?
1.1 openAI库简介
openAI库是OpenAI官方提供的Python SDK,旨在帮助开发者轻松调用OpenAI的API,实现自然语言处理(NLP)、图像生成、代码补全等AI功能。通过openAI库,开发者可以快速集成GPT、DALL·E等先进模型,构建智能应用。
1.2 openAI库的核心
- 简化开发流程:openAI库封装了复杂的API调用逻辑
- 支持多种模型:包括GPT-3、GPT-4、Codex等,满足不同场景需求。
- 灵活的参数配置:开发者可以通过调整参数,控制模型的输出质量、风格等。
- 高效的数据处理:支持批量请求、流式响应等功能,提升开发效率。
二、openAI库的安装和配置
2.1 安装openAI库
在开始使用openAI库之前,首先需要安装它。可以通过以下命令安装最新版本的openAI库:
pip install openai
2.2 配置API KEY
要使用openAI库,你需要一个OpenAI API KEY。以下是配置步骤:
- 之前写过CSDN的文章,教你如何获取OpenAI API KEY的教程,你可以前往这里查看: 【OpenAI】获取OpenAI API Key的多种方式全攻略:从入门到精通
- 注意!注意!注意! Python代码中如果要设置
base_url
和api_key
。那么在配置base_url
的时候你要注意一点,那就是在OpenAI库里面,Python的base_url
后面,自带了v1
的参数。所以base_url
后面也要加上v1
,如下代码:
from openai import OpenAI
client = OpenAI(api_key="这里是获取的api_key",base_url="https://api.aihao123.cn/luomacode-api/open-api/v1"
)response = client.chat.completions.create(messages=[# 把用户提示词传进来content{'role': 'user', 'content': "1+1等于几?帮我说列出详细步骤。"},],model='gpt-3.5-turbo', # 调用的模型stream=True # True 是流逝返回,False是非流逝返回
)# stream=False的时候,打开这个,启用非流式返回
# print(response.choices[0].message.content)# stream=True的时候,启用流示返回
for chunk in response:print(chunk.choices[0].delta.content, end="", flush=True)
三、openAI库的核心功能详解
3.1 文本生成:GPT模型的使用
GPT(Generative Pre-trained Transformer)是OpenAI最著名的模型之一,广泛应用于文本生成、对话系统等场景。以下是一个简单的文本生成示例:
from openai import OpenAIclient = OpenAI(api_key="这里是获取的api_key",base_url="https://api.aihao123.cn/luomacode-api/open-api/v1")
response = client.chat.completions.create(messages=[{'role': 'user', 'content': "写一篇关于人工智能的文章。"}, ],model='gpt-3.5-turbo',# stream=Falsestream=False,max_tokens=500
)
print(response.choices[0].message.content)# for chunk in response:
# print(chunk.choices[0].delta.content, end="", flush=True)
参数说明:
model
:指定使用的模型,如gpt-3.5-turbo
。messages
:输入的提示文本。stream
:等于False,是非流示返回。max_tokens
:生成文本的最大长度。
3.2 代码补全:Codex模型的使用
Codex是OpenAI专为代码生成优化的模型,支持多种编程语言。以下是一个代码补全示例:
response = client.chat.completions.create(messages=[{'role': 'user', 'content': "1+1"}, ],model='gpt-3.5-turbo',# stream=Falsestream=False,max_tokens=200
)
print(response.choices[0].message.content)
参数说明:
response = client.chat.completions.create()
:这个是代码补全的参数completions
。
3.3 图像识别:4O模型的使用
4O模型是OpenAI的大语言模型,可以根据图片生成对应文案。以下是一个图像识别示例:
目标:我要去识别这个图片
完整的代码如下:
from openai import OpenAIclient = OpenAI(api_key="这里是获取的api_key",base_url="https://api.aihao123.cn/luomacode-api/open-api/v1")
response = client.chat.completions.create(messages=[{"role": "user","content": [{"text": "这是什么?","type": "text"},{"image_url": {"url": ""},"type": "image_url"}]}],model='gpt-4o-2024-05-13',stream=False,max_tokens=200
)print(response.choices[0].message.content)
参数说明:
image_url
:参数里面的image_url
传入的是Base64,你也可以传入URL,但是传Base64响应会非常的快。这个是我用的转Base64的工具:转Base64- 等转完Base64后,在把内容贴到
image_url
即可。或者你可以直接调用Base64的代码库也可以。
四、openAI库的高级用法
4.1 批量请求与流式响应
为了提高效率,openAI库支持批量请求和流式响应。以下是一个批量请求示例:
response = client.chat.completions.create(messages=[{'role':'user', 'content': "10+5"},{'role': 'user', 'content': "2+1"}],model='gpt-3.5-turbo',stream=False,# stream=True,max_tokens=500
)print(response.choices[0].message.content)
4.3 错误处理与重试机制
在实际开发中,可能会遇到API调用失败的情况。以下是一个简单的错误处理示例:
import time
from os import error
from openai import OpenAIdef generate_text(prompt):client = OpenAI(api_key="这里是获取的api_key",base_url="https://api.aihao123.cn/luomacode-api/open-api/v1")try:response = client.chat.completions.create(messages=[{'role': 'user', 'content': prompt}, ],model='gpt-3.5-turbo',# stream=Falsestream=False,max_tokens=200)return response.choices[0].message.contentexcept error:time.sleep(10)return generate_text(prompt)if __name__ == '__main__':prompt = "床前明月光下一句是什么?并且输出完整的解释"print(generate_text(prompt))
五、相关文章
【OpenAI】(一)获取OpenAI API Key的多种方式全攻略:从入门到精通,再到详解教程!!
【VScode】(二)VSCode中的智能AI-GPT编程利器,全面揭秘CodeMoss & ChatGPT中文版
【CodeMoss】(三)集成13种AI大模型(GPT4、o1等)、支持Open API调用、自定义助手、文件上传等强大功能,助您提升工作效率! >>> - CodeMoss & ChatGPT-AI中文版
相关文章:

Python OpenAI 库开发指南:从入门到实战精通
在人工智能(AI)领域,OpenAI无疑是全球最受瞩目的机构之一。它推出的GPT系列模型、DALLE等创新技术,正在深刻改变各行各业。作为Python开发者,我们该如何快速上手并高效利用OpenAI的API,成为了提升个人竞争力…...

flash-attention保姆级安装教程
FlashAttention安装教程 FlashAttention 是一种高效且内存优化的注意力机制实现,旨在提升大规模深度学习模型的训练和推理效率。 高效计算:通过优化 IO 操作,减少内存访问开销,提升计算效率。 内存优化:降低内存占用…...
送给一年编程道路的自己
回望过去一年在编程道路上的成长与收获,是一个很有意义的过程。总结自己这一年的编程经历,不仅可以帮助你更清晰地了解自己的进步和不足,还能为未来的发展指引方向。以下是一些可能的收获,供你参考: 1. 技能提升 语言…...

LeRobot(1)
Train python lerobot/scripts/train.py \ policyact \ envaloha \ env.taskAlohaInsertion-v0 \ dataset_repo_idlerobot/aloha_sim_insertion_human \ load_data一直报错,忘记截图了,反正是ssh报错,下不下来,网…...
C++ 设计模式:组合模式(Composite Pattern)
链接:C 设计模式 链接:C 设计模式 - 迭代器模式 链接:C 设计模式 - 职责链模式 组合模式(Composite Pattern)是一种结构型设计模式,它允许你将对象组合成树形结构来表示“部分-整体”的层次结构。组合模式…...

OpenHarmony源码编译后烧录镜像教程,RK3566鸿蒙开发板演示
本文介绍瑞芯微主板/开发板编译OpenHarmony源码后烧录镜像的教程,触觉智能Purple Pi OH鸿蒙开发板演示。搭载了瑞芯微RK3566四核处理器,树莓派卡片电脑设计,支持开源鸿蒙OpenHarmony3.2-5.0系统,适合鸿蒙开发入门学习。 编译源码…...

强化学习(1)
Reinforcement Learning Goal-directed learing from ineraction with the environment. 1. Basic Element 基本元素 1.1 Agent 玩家 1.2 Environment 1.3 Goal 2. Main Element 主要元素 2.1 State 2.2 Action 状态与行为往复 2.3 Reward 目标:最大化总…...

【漏洞复现】金和OA C6 FileDownLoad.aspx 任意文件读取漏洞复现
免责声明 请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人负责,作者不为此承担任何责任。工具来自网络,安全性自测,如有侵权请联系删除。本次测试仅供学习使用,如若非法他用,与平台和本文作…...
开源模型应用落地-qwen2-7b-instruct-LoRA微调-Axolotl-单机多卡-RTX 4090双卡(七)
一、前言 本篇文章将使用Axolotl去高效微调QWen2系列模型,通过阅读本文,您将能够更好地掌握这些关键技术,理解其中的关键技术要点,并应用于自己的项目中。 二、术语介绍 2.1. LoRA微调 LoRA (Low-Rank Adaptation) 用于微调大型语言模型 (LLM)。 是一种有效的自适应策略,…...
Dockerfile 构建继承父镜像的 ENTRYPOINT 和 CMD
在 Docker 中,Dockerfile 是否继承其父映像的 ENTRYPOINT 和 CMD,取决于 Dockerfile 的编写方式。以下是规则: 1. CMD 的继承 子镜像会继承父映像的 CMD,但如果在子镜像的 Dockerfile 中显式定义了新的 CMD,就会覆盖…...

46. Three.js案例-创建颜色不断变化的立方体模型
46. Three.js案例-创建颜色不断变化的立方体模型 实现效果 知识点 Three.js基础组件 WebGLRenderer THREE.WebGLRenderer是Three.js提供的用于渲染场景的WebGL渲染器。它支持抗锯齿处理,可以设置渲染器的大小和背景颜色。 构造器 antialias: 是否开启抗锯齿&am…...

Linux系统离线部署MySQL详细教程(带每步骤图文教程)
1、登录官网下载对应的安装包 MySQL :: Developer Zone 2、将压缩包上传到服务器上,这里直接上传到/usr/local路径上 使用sftp工具上传到/usr/local目录上 3、解压压缩包 tar -xf mysql-8.0.39-linux-glibc2.17-x86_64.tar.xz 4、将mysql-8.0.39-linux-glibc2.17…...

【数据仓库】hive on Tez配置
hive on Tez 搭建 前提是hive4.0hadoop3.2.2数仓已搭建完成,现在只是更换其执行引擎 为Tez。搭建可参考【数据仓库】hive hadoop数仓搭建实践文章。 Tez 下载 下载地址 https://archive.apache.org/dist/tez/ 官网地址 https://tez.apache.org/releases/apac…...

Kubernetes Gateway API-3-TLS配置
1 简介 Gateway API 允许使用多种方式配置 TLS。本文档列出了各种TLS设置,并给出了如何有效使用它们的一般指南。 尽管本文档涵盖了 Gateway API 最常见的TLS配置形式,但某些实现也可能提供特定于实现的扩展,允许不同或更高级形式的TLS配置。除此文档外,值得阅读你所使用…...
C++ 设计模式:原型模式(Prototype Pattern)
链接:C 设计模式 链接:C 设计模式 - 工厂方法 链接:C 设计模式 - 抽象工厂 链接:C 设计模式 - 建造者模式 原型模式(Prototype Pattern)是一种创建型设计模式,它允许一个对象通过复制现有对象来…...

计算机网络 (12)物理层下面的传输媒体
前言 计算机网络物理层下面的传输媒体是计算机网络设备之间的物理通路,也称为传输介质或传输媒介,并不包含在计算机网络体系结构中,而是处于物理层之下。 一、传输媒体的分类 导向型媒体:电磁波被导引沿着固体媒体传播。常见的导向…...

SpringCloud 系列教程:微服务的未来(三)IService接口的业务实现
本文将介绍 IService 接口的基本业务操作、复杂业务操作、Lambda 方法的使用以及批量增加操作,帮助开发者深入了解如何高效地利用 MyBatis-Plus 提供的功能进行数据库操作。无论是简单的单表查询,还是复杂的多表联动,甚至是大数据量的批量操作…...
测试带宽上行方法
测试宽带上行速度的软件有多种,以下是一些常见的选择: Speedtest 平台支持:iOS、Android、Windows、MacOS等 特点:全球知名的网络测速软件,测试结果准确,支持多平台。用户可以选择最近的服务器进行测试&am…...

天天跳绳(???)
广东省人民政府门户网站 https://www.gd.gov.cn/zwgk/zdlyxxgkzl/whjg/content/post... 二沙岛变身智能“运动岛” - 广东省人民政府门户网站 2020年10月20日 广州二沙岛,犹如一颗璀璨明珠点缀在珠江之心,自然风光旖旎,功能分区清 … 公共…...

module ‘django.db.models‘ has no attribute ‘FieldDoesNotExist‘
module ‘django.db.models’ has no attribute ‘FieldDoesNotExist’ xadmin报错 原因 django与xadmin版本不匹配。 django==3.2.7 xadmin-django==3.0.2解决方案 在xadmin/view/edit.py的388行改为 from django.core import exceptions if self.request_method ==...
生成xcframework
打包 XCFramework 的方法 XCFramework 是苹果推出的一种多平台二进制分发格式,可以包含多个架构和平台的代码。打包 XCFramework 通常用于分发库或框架。 使用 Xcode 命令行工具打包 通过 xcodebuild 命令可以打包 XCFramework。确保项目已经配置好需要支持的平台…...

JavaSec-RCE
简介 RCE(Remote Code Execution),可以分为:命令注入(Command Injection)、代码注入(Code Injection) 代码注入 1.漏洞场景:Groovy代码注入 Groovy是一种基于JVM的动态语言,语法简洁,支持闭包、动态类型和Java互操作性,…...

RocketMQ延迟消息机制
两种延迟消息 RocketMQ中提供了两种延迟消息机制 指定固定的延迟级别 通过在Message中设定一个MessageDelayLevel参数,对应18个预设的延迟级别指定时间点的延迟级别 通过在Message中设定一个DeliverTimeMS指定一个Long类型表示的具体时间点。到了时间点后…...
2024年赣州旅游投资集团社会招聘笔试真
2024年赣州旅游投资集团社会招聘笔试真 题 ( 满 分 1 0 0 分 时 间 1 2 0 分 钟 ) 一、单选题(每题只有一个正确答案,答错、不答或多答均不得分) 1.纪要的特点不包括()。 A.概括重点 B.指导传达 C. 客观纪实 D.有言必录 【答案】: D 2.1864年,()预言了电磁波的存在,并指出…...
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…...
条件运算符
C中的三目运算符(也称条件运算符,英文:ternary operator)是一种简洁的条件选择语句,语法如下: 条件表达式 ? 表达式1 : 表达式2• 如果“条件表达式”为true,则整个表达式的结果为“表达式1”…...
WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)
一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解,适合用作学习或写简历项目背景说明。 🧠 一、概念简介:Solidity 合约开发 Solidity 是一种专门为 以太坊(Ethereum)平台编写智能合约的高级编…...

RabbitMQ入门4.1.0版本(基于java、SpringBoot操作)
RabbitMQ 一、RabbitMQ概述 RabbitMQ RabbitMQ最初由LShift和CohesiveFT于2007年开发,后来由Pivotal Software Inc.(现为VMware子公司)接管。RabbitMQ 是一个开源的消息代理和队列服务器,用 Erlang 语言编写。广泛应用于各种分布…...
MySQL 主从同步异常处理
阅读原文:https://www.xiaozaoshu.top/articles/mysql-m-s-update-pk MySQL 做双主,遇到的这个错误: Could not execute Update_rows event on table ... Error_code: 1032是 MySQL 主从复制时的经典错误之一,通常表示ÿ…...

stm32wle5 lpuart DMA数据不接收
配置波特率9600时,需要使用外部低速晶振...