位置: IT常识 - 正文

Python Module — OpenAI ChatGPT API

编辑:rootadmin
原力计划Python Module — OpenAI ChatGPT API 目录文章目录目录OpenAI Python SDKopenai.ChatCompletion 模块openai.ChatCompletion.create 函数OpenAPI client 代码示例OpenAI Python SDK官方文档:https://platform.openai.com/docs/api-reference/introduction

推荐整理分享Python Module — OpenAI ChatGPT API,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

Python Module — OpenAI ChatGPT API

OpenAI Python SDK 用于开发与 OpenAI RESTful API 进行交互的客户端应用程序,包含了 OpenAI 的各种人工智能模型的 API。

OpenAI Python SDK 提供了多个模块,每个模块都具有一套自包含的 APIs,包括:

openai.ChatCompletion:用于访问 ChatGPT 语言模型,实现自然语言生成和处理。openai.Davinci:用于访问 OpenAI 最大的 GPT-3 语言模型,提供了更强大的语言处理能力。openai.GPT:用于访问 OpenAI 较小的 GPT-3 语言模型,提供了基本的语言处理能力。openai.Language:用于访问 OpenAI 语言模型,提供了自然语言生成和处理的能力。openai.Image:用于访问 DALL-E 图像生成模型,实现图像的生成和处理。openai.File:用于访问 OpenAI 文件服务器,实现文件的上传和下载。openai.Organization:用于管理 OpenAI 账户、工作区和 API Keys 等。openai.ChatCompletion 模块

OpenAI ChatCompletion 模块用于访问 ChatGPT 语言模型,用于实现对话式(Chat)AI 应用程序。

openai.ChatCompletion.create 函数编程示例:https://github.com/JmilkFan/easy-chat-prompts

函数作用:与 ChatGPT 进行 C/S 交互,返回 AI 模型生成的对话文本。注意,该接口是 Stateless 的,每次调用都不包含对话的上下文。这意味着需要客户端应用程序自己维护 “聊天记录“。

函数原型:

model:指示要访问的 AI 模型,例如:gpt-3.5-turbo(计费 $0.002 / 1K tokens)。messages:对话消息,字典列表类型,字典包括下列 Keys。

role:指示发起对话的角色。枚举:user(发送用户对话)、system(发送给 AI 模型的提示符)。content:指示发起对话的内容。assistant:指示 ChatGPT 回答的内容,用于传递 “聊天记录”。max_tokens:指示响应内容的 Token 数量,例如:1024、2048、4096(MAX)。temperature:用于控制输出文本的多样性和创造性。它是一个介于 0 到 1 之间的实数,表示 AI 模型在生成每个单词时的随机程度。更高的数值会导致更多的随机性和更多的创造性,但可能会降低输出的质量和连贯性。反之,则会产生较为确定性的输出,但可能会使输出变得单调和缺乏创意。top_p:用于控制模型生成的单词的概率分布。它是一个介于 0 到 1 之间的实数,表示模型在生成下一个单词时,只考虑最有可能的前 top_p 个单词。当 top_p 较小时,生成的文本更加精细和准确,但可能会导致过度确定性和缺乏多样性。反之,当 top_p 较大时,生成的文本更加多样化,但可能会导致出现不合适的单词和不相关的文本。frequency_penalty:用于控制生成对话文本中重复的程度,值越大则重复的文本越少,值越小则重复的文本越多。如果将其设置为 0,则 AI 模型将生成最多数量的重复文本。presence_penalty:用于控制模型生成是否包含与给定文本重叠的片段,值越大则生成文本的准确性越高,值越小则生成文本的多样性越大。stop:用于控制对话文本生成的终止条件。n:指示生成对话文本的个数。max_examples:用于控制生成对话文本的数量。logprobs:在对话文本生成时输出单词出现的概率。echo:是否在生成对话文本后输出到控制台。def create( model: str, messages: str, max_tokens: Optional[int] = None, temperature: Union[int, float] = 0.5, top_p: Union[int, float] = 1.0, frequency_penalty: Union[int, float] = 0, presence_penalty: Union[int, float] = 0, stop: Optional[Union[str, List[str]]] = None, n: Optional[int] = 1, max_examples: Optional[int] = None, logprobs: Optional[int] = None, echo: bool = True, **kwargs,) -> Dict[str, Union[str, List[str]]]: pass原始 HTTP 请求样式:curl https://api.openai.com/v1/chat/completions \ -H "Content-Type: application/json" \ -H "Authorization: Bearer $OPENAI_API_KEY" \ -d '{ "model": "gpt-3.5-turbo", "messages": [{"role": "user", "content": "Say this is a test!"}], "temperature": 0.7 }'原始 HTTP 响应样式:{ "id":"chatcmpl-abc123", "object":"chat.completion", "created":1677858242, "model":"gpt-3.5-turbo-0301", "usage":{ "prompt_tokens":13, "completion_tokens":7, "total_tokens":20 }, "choices":[ { "message":{ "role":"assistant", "content":"\n\nThis is a test!" }, "finish_reason":"stop", "index":0 } ]}“聊天记录“ 请求样式:messages = [ {"role": "system", "content": "You are a helpful assistant."}, {"role": "user", "content": "Who won the world series in 2020?"}, {"role": "assistant", "content": "The Los Angeles Dodgers won the World Series in 2020."}, {"role": "user", "content": "Where was it played?"}]OpenAPI client 代码示例import openaiimport configparserimport timeconfig = configparser.ConfigParser()config.read('./config.ini')class OpenAIClient(object): def __init__(self): super(OpenAIClient, self).__init__() openai.api_key = config.get('OpenAI', 'API_SECRET_KEY') self.max_retry = 3 self.retry_delay = 5 self.timeout = 10 def _make_request(self, role, content): print("*************************************") print("request role: ", role) print("request content: ", content) print("*************************************") if role not in ['user', 'system', 'assistant']: print(f'role [{role}] not found.') raise retry_count = 0 while retry_count < self.max_retry: try: response = openai.ChatCompletion.create( model=config.get('OpenAI', 'MODEL'), messages=[{"role": role, "content": content}], max_tokens=2048, n=1, stop=None, temperature=0.7, timeout=self.timeout ) return response except Exception as e: print(f"Failed to connect to API server, detail error as {e}, retrying in {self.retry_delay} seconds ({retry_count+1}/{self.max_retry})") time.sleep(self.retry_delay) retry_count += 1 def chat_request(self, content): role = "user" return self._make_request(role, content) def prompt_request(self, content): role = "system" return self._make_request(role, content) def parser_response(self, response): result = [] choices = response.choices for cho in choices: result.append( { 'index': cho['index'], 'role': cho['message']['role'], 'content': cho['message']['content'] } ) return resultif __name__ == '__main__': cli = OpenAIClient() resp = cli.chat_request(content='hello!') print("Test response: ", cli.parser_response(resp))./config.ini[OpenAI]API_SECRET_KEY = your_api_keyMODEL = gpt-3.5-turbo
本文链接地址:https://www.jiuchutong.com/zhishi/299606.html 转载请保留说明!

上一篇:微信小程序:用户微信登录流程(附:流程图+源码)(微信小程序用电脑怎么打开)

下一篇:Opencv(C++)系列学习---opencv_contrib安装(opencv1.0)

  • 淘宝人生入口在哪里(淘宝人生入口在更多频道看不到怎么回事)

    淘宝人生入口在哪里(淘宝人生入口在更多频道看不到怎么回事)

  • 钉钉学生号怎么改成家长号(钉钉学生号怎么获得)

    钉钉学生号怎么改成家长号(钉钉学生号怎么获得)

  • qq音乐背景动态怎么关(qq音乐背景动态自动的吗)

    qq音乐背景动态怎么关(qq音乐背景动态自动的吗)

  • OPPO Ace2有多厚呢(oppoace2厚吗)

    OPPO Ace2有多厚呢(oppoace2厚吗)

  • 秘乐短视频实名认证可以取消吗(秘乐短视频实名认证有风险吗)

    秘乐短视频实名认证可以取消吗(秘乐短视频实名认证有风险吗)

  • 微信红包怎么指定人抢(微信红包怎么指定一个人领)

    微信红包怎么指定人抢(微信红包怎么指定一个人领)

  • 三星a60手机自动重启(三星手机自动关闭)

    三星a60手机自动重启(三星手机自动关闭)

  • 网络安全特征有哪些(网络安全特征有那些方面)

    网络安全特征有哪些(网络安全特征有那些方面)

  • flaal10是华为什么型号手机(flaal10是华为什么型号手机能升级鸿蒙)

    flaal10是华为什么型号手机(flaal10是华为什么型号手机能升级鸿蒙)

  • 华为耳机能连苹果吗(华为耳机连苹果手机怎么看电量)

    华为耳机能连苹果吗(华为耳机连苹果手机怎么看电量)

  • 小米max4几月份上市(小米mix4预计发布时间)

    小米max4几月份上市(小米mix4预计发布时间)

  • qq邮箱已发邮件在哪里(qq邮箱已发邮件可以撤回吗)

    qq邮箱已发邮件在哪里(qq邮箱已发邮件可以撤回吗)

  • iphone8续航时间(iphone8的续航)

    iphone8续航时间(iphone8的续航)

  • 电脑显示adiskreaderroroccurred如何解决(电脑显示屏不亮但是主机已开机)

    电脑显示adiskreaderroroccurred如何解决(电脑显示屏不亮但是主机已开机)

  • mate 20出现hd是什么(mate20 hd标志)

    mate 20出现hd是什么(mate20 hd标志)

  • oppo的nfc功能在哪里(oppo手机nfc功能)

    oppo的nfc功能在哪里(oppo手机nfc功能)

  • 苹果11怎么调来电闪光灯(苹果11怎么调来电铃声)

    苹果11怎么调来电闪光灯(苹果11怎么调来电铃声)

  • 微信开启横屏模式有什么用(微信开启横屏模式没用)

    微信开启横屏模式有什么用(微信开启横屏模式没用)

  • 原手机通讯录如何到新手机上(原手机通讯录如何删除联系人)

    原手机通讯录如何到新手机上(原手机通讯录如何删除联系人)

  • 手机反向充电怎么用(手机反向充电怎么关闭)

    手机反向充电怎么用(手机反向充电怎么关闭)

  • iphone xs max发热怎么办(iphonexsmax发热)

    iphone xs max发热怎么办(iphonexsmax发热)

  • cun-tl00是什么型号(cunal00)

    cun-tl00是什么型号(cunal00)

  • 怎样看华为手机是不是全网通(怎样看华为手机的出厂日期)

    怎样看华为手机是不是全网通(怎样看华为手机的出厂日期)

  • 红魔呼吸灯怎么设置(红魔手机后面有个呼吸灯吗)

    红魔呼吸灯怎么设置(红魔手机后面有个呼吸灯吗)

  • 税控盘是干什么用的
  • 报税申报不了
  • 企业当期的所得税费用
  • 空调维修保养征收什么税?
  • 增值税发票如何作废流程
  • 现金流量表现金指的什么
  • 哪些进项税额不可以抵扣
  • 承担客户装修费怎么入账
  • 简易征收应纳税额计算
  • 跨年冲减费用
  • 营改增后自建厂房抵扣
  • 私车公用产生的过路费怎么开发票
  • 库存商品盘盈盘亏表
  • 进项发票未抵扣部份开红冲后当月能抵扣吗?
  • 工会经费的缴费主体
  • 公司个人所得税怎么申报
  • 车间改造用的材料有哪些
  • 版权使用费属于什么税目
  • 农产品增值税免税政策
  • 母公司并购子公司需要股东会决议吗
  • 个体工商户怎样开发票
  • qqpcrtp.exe是什么进程 如何删除qqpcrtp进程
  • 全民游戏盒子怎么卸载
  • 汇兑损益怎么记账
  • 百度有钱花借钱会上征信吗
  • 自产产品用于业务招待,成本10万,售价20万
  • 自产产品用于业务招待 如何申报企业所得税
  • 公司的清洁费用是什么科目
  • PHP:mcrypt_get_key_size()的用法_Mcrypt函数
  • php写一个函数,算出两个文件的相对路径
  • 海带下载
  • 房屋装修固定资产置换
  • 工资属于营业成本
  • 【深度学习】pix2pix GAN理论及代码实现与理解
  • 量子退火算法入门6
  • 公司开的餐费专票可以抵扣吗
  • 盈余公积金的账务处理
  • 所得税时间性差异
  • 商品过期的会计分录
  • 帝国cms安装教程
  • js中同步如何理解
  • python中numpy数组的拼接、合并
  • 增值税开票系统客服电话
  • 电子发票自己打印黑白有效吗
  • sql按照日期范围查询
  • 暂估的原材料用不用记原材料明细账
  • 职工报销费用
  • 企业未开票收入怎么入账
  • 支付货款退回如何处理
  • 跨月的发票还能入账吗
  • 相关损坏维修成本是什么
  • 公司变更名字后,公账怎么办
  • 外经证的办理流程
  • 医院医保会计的岗位职责
  • 电子发票开具流程?
  • 生产经营所得成本费用怎么算
  • 私营企业会计退休年龄50还是55
  • 消费税的科目设置在哪里
  • 非常详细的魔方公式图解
  • sql语句基础教程
  • 系统诊断工具命令
  • windows环境是什么意思
  • 去掉电脑右下角显示的时间
  • win1020h2正式版
  • mousemenu是什么文件夹
  • windows7找不到无线
  • win8安全和维护在哪
  • mysqld是什么进程
  • windows7 游戏
  • 举例说明什么是判断
  • jquery动态添加
  • cocos2d开发的知名游戏
  • javascript新手教程
  • nodejs实战教程
  • 你所不知道的童话动画版免费观看第二季
  • android studio中r文件在哪
  • 浙江蹦极哪里好玩
  • 何为标兵称号
  • 养猪环保局有什么新政策
  • 小微企业所得税5%优惠政策
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设