位置: IT常识 - 正文

chatGPT之Python API启用上下文管理

编辑:rootadmin
chatGPT之Python API启用上下文管理

推荐整理分享chatGPT之Python API启用上下文管理,希望有所帮助,仅作参考,欢迎阅读内容。

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

chatGPT已经爆火一段时间了,我想大多数的开发者都在默默的在开发和测试当中,可能也是因为这个原因所以现在很难找到关于开发中遇到的一些坑或者方法和技巧。

为什么别人的机器人能联想之前的语料,而你的却像个每次都只如初见的高冷机器人?

我也是参考官方文档去阅读和理解的,但是有时候官方文档以为你很懂了,就没有太多说明,废话不多说下面我跟大家讲一下API调用时如何启用上下文管理的。

官方案例:

# Note: you need to be using OpenAI Python v0.27.0 for the code below to workimport openaiopenai.ChatCompletion.create(model="gpt-3.5-turbo",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?"}])

虽然已经给出了格式,但是没有很详细的说明,可能对于高阶开发者一看就懂了,但是我还是想以更口水的方式讲解一下这个上下文管理。

先看一下我一个简单的代码(还没有启用上下文管理):

import openaiopenai.api_key = "你的sk-key"msg = [{"role": "user", "content": "你好chatGPT"}]# 结构化数据并进行提交completion = openai.ChatCompletion.create(# max_tokens = inf # 默认inf 最大令牌数presence_penalty = 1, # 惩罚机制,-2.0 到 2.0之间,默认0,数值越小提交的重复令牌数越多,从而能更清楚文本意思frequency_penalty = 1, # 意义和值基本同上,默认0,主要为频率temperature = 1.0, # 温度 0-2之间,默认1 调整回复的精确度使用n = 1, # 默认条数1user = ids, # 用户ID,用于机器人区分不同用户避免多用户时出现混淆model = "gpt-3.5-turbo",    # 这里注意openai官方有很多个模型messages = msg)value = completion.choices[0].message.content    # chatGPT返回的数据

这是一个最基本的结构,其中参数model和messages是必须要有的两个形参。

chatGPT之Python API启用上下文管理

加入上下文管理的代码:

import openaiopenai.api_key = "你的sk-key"msg = [{"role": "system", "content": "你的名字叫玖河AI,你是一个插件,你的开发者是玖河."},{"role": "user", "content": "你好chatGPT"},{"role": "assistant", "content": "您好,有什么需要我帮忙的问题吗?"},{"role": "user", "content": "我的名字叫高启强,我的妹妹叫高启兰,我们是兄妹关系。记住了吗?"}        {"role": "assistant", "content": "好的,您叫高启强,您的妹妹叫高启兰,是亲兄妹关系。谢谢您提供信息让我更了解你们~"},        {"role": "user", "content": "你现在在哪里?"},        {"role": "assistant", "content": "作为一款智能Ai助手,我并没有实际的位置。我只是在云端中运行,在等待用户输入指令时保持睡眠状态。"},        {"role": "user", "content": "我的妹妹是谁?"},        {"role": "assistant", "content": "您之前告诉我,您的妹妹叫高启兰。"},        {"role": "user", "content": "你的名字叫什么?"},        {"role": "assistant", "content": "我的名字叫玖河AI是一个叫玖河的开发者开发的插件"}        ]# 结构化数据并进行提交completion = openai.ChatCompletion.create(# max_tokens = inf # 默认inf 最大令牌数presence_penalty = 1, # 惩罚机制,-2.0 到 2.0之间,默认0,数值越小提交的重复令牌数越多,从而能更清楚文本意思frequency_penalty = 1, # 意义和值基本同上,默认0,主要为频率temperature = 1.0, # 温度 0-2之间,默认1 调整回复的精确度使用n = 1, # 默认条数1user = ids, # 用户ID,用于机器人区分不同用户避免多用户时出现混淆model = "gpt-3.5-turbo", # 这里注意openai官方有很多个模型messages = msg)value = completion.choices[0].message.content # chatGPT返回的数据

下面启用上下文管理的数据结构和没有启用的数据结构略有不同:

① system 代表系统设定(也就是告诉chatGPT他的角色)

② user 表示用户

③ assistant 表示GPT的回复

有几个点需要跟大家说一下,避免踩坑!

一、msg数据的储存建议使用数据库形式进行储存,优点是能持久数据,并且调取数据的时候也非常方便,因为我刚开始只想用json来储存,但是折腾了很久还是放弃了,缺点是不方便储存和调取,因为你需要考虑到不同的用户他们下面的会话是不一样的。

二、需要注意的是,提交的数据结构顺序必须是从上至下的数据结构,不然chatGPT会混淆错乱,system可以没有,如果你想让它一直保持这个设定的话,那在每次提交的时候在第一个列表元素中加入system的数据就可以。

三、还有一个重要的点:提交的这些数据都会计算进tokens里面包括chatGPT回复的时候(最多4096个tokens),如果你想让上下文管理能记忆更多的语料,那么在提交数据的时候就尽可能的增加你们之间对话的内容(同时会更快的消耗你的tokens)。

四、截止2023年3月14日前:chatGPT的会员价格为20美元/月 ,tokens按量收费。通俗的说就是想手机卡一样,每个月有月租,通话另外计费。chatGPT Plus会员的好处就是速度能更快,并且稳定,白嫖版的也能用,就是速度会慢一些而且不稳定容易挂掉。

如果我的文章能帮助到你,也希望能给我点个关注或者赞!

转载请注明出处:https://mp.csdn.net/mp_blog/creation/success/129541012

本文链接地址:https://www.jiuchutong.com/zhishi/299792.html 转载请保留说明!

上一篇:猿创征文|【React 三】组件实例的三大属性(state、props、refs)(关于猿猴的作文)

下一篇:用 JSP 连接 MySQL 登入注册项目实践(JSP + HTML + CSS + MySQL)(jsp连接mysql8数据库)

  • 小米mix4怎么设置锁屏时间(小米mix4怎么设置)

    小米mix4怎么设置锁屏时间(小米mix4怎么设置)

  • 华为荣耀20保修期多久(华为荣耀20保修几年)

    华为荣耀20保修期多久(华为荣耀20保修几年)

  • p40可以插内存卡吗(p40插内存卡的方法)

    p40可以插内存卡吗(p40插内存卡的方法)

  • 怎么关闭华为省电模式(怎么关闭华为省电功能)

    怎么关闭华为省电模式(怎么关闭华为省电功能)

  • 录音m4a是什么(录音m4a是什么格式)

    录音m4a是什么(录音m4a是什么格式)

  • sdm7250是什么处理器(sdm670是什么处理器怎么样)

    sdm7250是什么处理器(sdm670是什么处理器怎么样)

  • 用了淘金币如果退款会退回来吗(用了淘金币退款怎么办)

    用了淘金币如果退款会退回来吗(用了淘金币退款怎么办)

  • 手机修改mac的后果(手机 mac 修改)

    手机修改mac的后果(手机 mac 修改)

  • 快手平台怎么抽成(快手平台怎么抽佣金)

    快手平台怎么抽成(快手平台怎么抽佣金)

  • 微信群如何100人同时视频(微信群如何100人建群)

    微信群如何100人同时视频(微信群如何100人建群)

  • 拼多多虚拟商品怎么退货(拼多多虚拟商品保证金多少)

    拼多多虚拟商品怎么退货(拼多多虚拟商品保证金多少)

  • 对方关机微信能语音吗(对方关机微信能定位吗)

    对方关机微信能语音吗(对方关机微信能定位吗)

  • powerpoint主要用途是什么(powerpoint主要用于制作什么的软件)

    powerpoint主要用途是什么(powerpoint主要用于制作什么的软件)

  • oppoa11x支持快充吗 (oppoa11x支持快充120w吗)

    oppoa11x支持快充吗 (oppoa11x支持快充120w吗)

  • 苹果xr双卡是双4g吗(苹果xr双卡什么意思)

    苹果xr双卡是双4g吗(苹果xr双卡什么意思)

  • 抖音怎么弄私密(抖音怎么弄私密评论)

    抖音怎么弄私密(抖音怎么弄私密评论)

  • 华为优享版是什么意思(华为商城优享购是什么)

    华为优享版是什么意思(华为商城优享购是什么)

  • 苹果xr亮度怎么老变暗(苹果xr亮度怎么调到最亮)

    苹果xr亮度怎么老变暗(苹果xr亮度怎么调到最亮)

  • 苹果nfc功能怎么开启门禁卡(苹果nfc功能怎么开启地铁卡)

    苹果nfc功能怎么开启门禁卡(苹果nfc功能怎么开启地铁卡)

  • bixby按键自定义(bixby键自定义成电源键功能)

    bixby按键自定义(bixby键自定义成电源键功能)

  • CUDA-v11.2下载以及相应版本cuDNN(cuda10.1下载)

    CUDA-v11.2下载以及相应版本cuDNN(cuda10.1下载)

  • 基于stm32的太空人温湿度时钟项目——DHT11(HAL库)(基于stm32的飞行器)

    基于stm32的太空人温湿度时钟项目——DHT11(HAL库)(基于stm32的飞行器)

  • 织梦(dedecms)程序如何在后台添加新用户注册功能方法(织梦森林官网)

    织梦(dedecms)程序如何在后台添加新用户注册功能方法(织梦森林官网)

  • python中Allure框架是什么?(python框架的作用)

    python中Allure框架是什么?(python框架的作用)

  • 扣非净利润和净利润的区别举例说明
  • 营业税金及附加怎么计提
  • 运输行业一般纳税人税率
  • 未开票收入退回可以冲税吗
  • 房地产企业土地出让金抵减销项税额
  • 增值税普票税额怎么算出来的
  • 劳务报酬自行申报时间
  • 生产成本月末结转到本年利润里吗
  • 更换电脑后个税信息如何导入
  • 合同和发票计量一样吗
  • 行政单位预算资金拨付流程
  • 公司合并是不是先变更股权
  • 小规模纳税人费用票怎么做账
  • 调整跨期收入是否调增值税
  • 汽车贷款利息是什么
  • 辅助生产车间最后结转到哪里
  • 加速折旧做账
  • 漏提折旧可以所得税扣除吗
  • 多交税费退税会计处理
  • 商业营业用房经营租赁税率是多少
  • 从公司账户取现金
  • 外出经营活动税收管理证明和跨区域涉税事项报告表
  • 增值税已交税金什么情况下使用
  • 年终奖缴税将有大变化
  • 同一控制下的企业合并的会计核算方法
  • 固定资产拆除后账务处理
  • 公积金可以在个税前全额扣除吗
  • 苹果手机miracast在哪里找到
  • 投资收益率的作用
  • 对公账户是否有银行卡号
  • 个体户个人所得税免征额是多少
  • 默认网关和dns怎么填
  • 便秘怎么办 女性
  • laravel with查询指定字段
  • 现金清查的会计科目
  • 山上覆盖着皑皑白雪
  • phpcgi远程代码执行漏洞
  • 库存股属于什么
  • thinkphp登录验证
  • 盈余公积转增资本什么意思
  • vue使用技巧
  • php解析xml文件
  • 投资入股的会计处理
  • 打印空白表格怎么制作
  • 个人所得税纳税记录怎么查询
  • 未开票收入如何做会计分录
  • 汽车折旧年限是几年如何计算
  • 想要上海名媛群群号
  • 非货币性资产交换以公允价值为基础进行计量
  • 抵扣是什么意思大白话...举例
  • 报表怎么报送
  • 固定资产加速折旧是什么意思
  • 预收账款可以用吗
  • 计提折旧会计分录怎么做
  • 餐厅吃饭不小心把餐具打破需要赔吗?
  • 简易征收应纳税额
  • 处置子公司利润表怎么合并
  • 营业外支出的用法
  • 注册公司可以代办吗法人需要到场吗?
  • 商业银行的固定资产
  • sql server 判断数据是否存在
  • sql server数据库怎么导出
  • Win10预览版拆弹
  • c盘满了怎么释放空间
  • win8自带的视频播放器打不开
  • wcesmgr.exe - wcesmgr 是什么进程
  • windowsxp怎么改windows7
  • winxp系统介绍
  • linux挂起
  • win系统找回删除文件
  • vs2012配置opencv4.8
  • 如何从0开始赚钱
  • 深入理解两个大计重要论断心得体会
  • Python爬取网易云音乐歌单内歌曲歌手封面播放地址
  • python str()怎么用
  • python语言中
  • 税务局上班吗今天
  • 收到免税的苗木发票怎么做账
  • 工会开票要求
  • 如何查询税控盘是否注销成功
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设