首页 > 编程语言 >【openAI库】Python语言openAI库详解:从入门到精通(从0到1手把手教程)

【openAI库】Python语言openAI库详解:从入门到精通(从0到1手把手教程)

时间:2025-01-10 09:56:17浏览次数:1  
标签:Python 手把手 content url api openAI OpenAI response

在人工智能(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 OpenAI

client = 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=False
    stream=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=False
    stream=False,
    max_tokens=200
)
print(response.choices[0].message.content)

参数说明:

response = client.chat.completions.create():这个是代码补全的参数completions。

3.3 图像识别:4O模型的使用

4O模型是OpenAI的大语言模型,可以根据图片生成对应文案。

以下是一个图像识别示例:

目标:我要去识别这个图片图片完整的代码如下:

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=[
        {
            "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.2 错误处理与重试机制

在实际开发中,可能会遇到API调用失败的情况。以下是一个简单的错误处理示例:

import time
from os import error
from openai import OpenAI

def 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=False
            stream=False,
            max_tokens=200
        )
        return response.choices[0].message.content
    except error:
        time.sleep(10)
        return generate_text(prompt)

if __name__ == '__main__':
    prompt = "床前明月光下一句是什么?并且输出完整的解释"
    print(generate_text(prompt))

原创 hpstream 爱学习的蝌蚪

标签:Python,手把手,content,url,api,openAI,OpenAI,response
From: https://www.cnblogs.com/o-O-oO/p/18663373

相关文章

  • Python用K-Means均值聚类、LRFMC模型对航空公司客户数据价值可视化分析指标应用
    全文链接:https://tecdat.cn/?p=38708原文出处:拓端数据部落公众号分析师:YulingFang信息时代的来临使得企业营销焦点从产品中心转向客户中心,客户关系管理成为企业的核心问题。客户关系管理的关键是客户分群,通过客户分群,区分无价值客户和高价值客户,同时更好的了解客户的特征,使企......
  • 手把手教你配置EtherCAT转Modbus网关连接TwinCAT3
    在工业自动化控制系统中,常常需要整合不同的通信协议设备。本案例旨在展示如何利用捷米特JM-ECT-RTU协议转换网关模块,实现EtherCAT网络与Modbus设备之间的无缝连接,并在TwinCAT3环境中进行有效配置,以构建一个稳定可靠的自动化控制系统ETHERCAT 技术参数捷米JM-ECT-RTU网......
  • 跟我一起学 Python 数据处理(二十六):PDF 数据提取技巧与问题解决策略
    跟我一起学Python数据处理(二十六):PDF数据提取技巧与问题解决策略在Python数据处理的学习之旅中,我们已经走过了不少路程,今天继续深入探索PDF文件处理的核心技巧与方法,旨在帮助大家进一步提升数据处理能力,解决实际工作中遇到的难题。一、slate库处理PDF文件的深入......
  • 跟我一起学 Python 数据处理(二十五):PDF 文件处理入门与工具抉择
    跟我一起学Python数据处理(二十五):PDF文件处理入门与工具抉择在数据处理的征程中,我们时常会遇到各种格式的数据,而PDF作为一种常见但处理难度较大的格式,掌握其处理方法至关重要。本文旨在与大家共同探索Python处理PDF文件的奥秘,帮助大家提升数据处理技能。一、PDF......
  • Python Matplotlib 教程- Matplotlib 如何进行数据点标记
    PythonMatplotlib数据点标记在数据可视化中,数据点标记是非常重要的部分。无论是绘制折线图、散点图还是柱状图,清晰地标记关键数据点可以帮助观众快速理解图表的核心信息。本篇文章将详细介绍如何在Python的Matplotlib中实现数据点标记,从基础使用到高级自定义,帮助新手快速上......
  • Python Matplotlib 教程- Matplotlib 如何自定义样式
    PythonMatplotlib样式和自定义Matplotlib是一个强大的Python数据可视化库,提供丰富的绘图功能。在实际使用中,熟悉其样式和自定义技巧可以让你的图表更加专业和美观。本文将简要介绍Matplotlib样式和一些常用的自定义方法。1.设置全局样式Matplotlib提供了一些预设的样......
  • Python + Appium 自动化操作微信入门(超详细)
    Appium是一个开源的自动化测试工具,支持Android、iOS平台上的原生应用,支持Java、Python、PHP等多种语言。Appium封装了Selenium,能够为用户提供所有常见的JSON格式的Selenium命令以及额外的移动设备相关的控制命令,比如:多点触控手势、屏幕朝向等。环境本文主要环境如下:......
  • python 代码实现了从NetCDF格式的气象数据文件中提取亮温(TBB)数据,识别中尺度对流系统(MC
    importnumpyasnpimportnetCDF4asncimportosimportcv2fromskimageimportmeasureimportmatplotlib.pyplotasplt#定义常量和参数DATA_DIR=r'E:\Data\FY4-TBB_ALL'TRACK_OUTPUT=r'E:\Data\mcs_tracks.txt'OVERLAP_THRESHOLD=0.3......
  • Python代码实现了一个图像匹配系统的图形用户界面(GUI)应用程序
    importtkinterastkfromtkinterimportfiledialog,messagebox,ttkfromPILimportImage,ImageTkimportosimportcv2importmatplotlib.pyplotaspltimportnumpyasnpfromdatetimeimportdatetimeimportsysclassImageMatcherApp:def__init_......
  • Python代码实现了对股票数据的读取、筛选、分析和可视化功能
    #-*-coding:utf-8-*-"""SpyderEditorThisisatemporaryscriptfile."""#读取股票数据importpandasaspdimportmatplotlib.pyplotasplt#读取数据data=pd.read_excel('D:/第3组-数据.xlsx')#切片取2024-01-02至2024-12-20......