当前位置:   article > 正文

手把手教你打造自己的AI聊天机器人程序(讯飞星火API)

星火api

案例背景

最近发现科大的讯飞星火大模型可以申请API试用了,我一直想用chatgpt的API,一是因为收费买不起,二是因为网络不方便.....

现在有了科大讯飞这个国内免费的,当然要试试。

目前讯飞星火可以申请试用他们的模型API,但是只有200w的token上限(一下就能花光),而且目前是测试阶段,只能自己做点小玩意试用一下。

本篇就是教大家怎么申请,然后怎么写代码封装为.exe程序,然后随时都可以使用AI进行对话。


申请准备

讯飞星火官网:讯飞星火认知大模型-AI大语言模型-星火大模型-科大讯飞

然后点击api测试

 然后点击申请:

进入申请界面,但别急着填信息,我们要先申请一个APPID号,翻到最下面:

全部都填好:

之后就能得到一个APPID:

记住它,然后回到我们刚刚申请的界面,填好所有的信息提交:

我们需要等一会,大概一个小时内就能通过申请。


通过后,我们可以在工单中心查看自己的信息:

然后我们进入平台首页,查看自己的控制台

点击我们申请的应用:

点击左边的星火大模型V1.5/V2.0

就能查看到我们这个申请的APPID还有API的密码等等信息:

有了这个信息后,就可以写代码了。


编写代码

源文档链接:星火认知大模型Web文档 | 讯飞开放平台文档中心 (xfyun.cn)

想详细了解可以看看,只想学会怎么调用API就看我下面代码就行。

首先要装一个库,websocket  和 websocket_client

先在命令行里面输入:(按win+R,然后输入cmd打开命令行)

pip install websocket

可能会比较慢,报错的话多重复试试 

然后再安装:

pip install websocket_client

就完成了环境的准备。(其他的包应该都是py内置的)

新建一个py文件,名字就命名为讯飞星火,然后输入:

  1. import _thread as thread
  2. import base64
  3. import datetime
  4. import hashlib
  5. import hmac
  6. import json
  7. from urllib.parse import urlparse
  8. import ssl
  9. from datetime import datetime
  10. from time import mktime
  11. from urllib.parse import urlencode
  12. from wsgiref.handlers import format_date_time
  13. import websocket # 使用websocket_client
  14. answer = ""
  15. class Ws_Param(object):
  16. # 初始化
  17. def __init__(self, APPID, APIKey, APISecret, Spark_url):
  18. self.APPID = APPID
  19. self.APIKey = APIKey
  20. self.APISecret = APISecret
  21. self.host = urlparse(Spark_url).netloc
  22. self.path = urlparse(Spark_url).path
  23. self.Spark_url = Spark_url
  24. # 生成url
  25. def create_url(self):
  26. # 生成RFC1123格式的时间戳
  27. now = datetime.now()
  28. date = format_date_time(mktime(now.timetuple()))
  29. # 拼接字符串
  30. signature_origin = "host: " + self.host + "\n"
  31. signature_origin += "date: " + date + "\n"
  32. signature_origin += "GET " + self.path + " HTTP/1.1"
  33. # 进行hmac-sha256进行加密
  34. signature_sha = hmac.new(self.APISecret.encode('utf-8'), signature_origin.encode('utf-8'),
  35. digestmod=hashlib.sha256).digest()
  36. signature_sha_base64 = base64.b64encode(signature_sha).decode(encoding='utf-8')
  37. authorization_origin = f'api_key="{self.APIKey}", algorithm="hmac-sha256", headers="host date request-line", signature="{signature_sha_base64}"'
  38. authorization = base64.b64encode(authorization_origin.encode('utf-8')).decode(encoding='utf-8')
  39. # 将请求的鉴权参数组合为字典
  40. v = {
  41. "authorization": authorization,
  42. "date": date,
  43. "host": self.host
  44. }
  45. # 拼接鉴权参数,生成url
  46. url = self.Spark_url + '?' + urlencode(v)
  47. # 此处打印出建立连接时候的url,参考本demo的时候可取消上方打印的注释,比对相同参数时生成的url与自己代码生成的url是否一致
  48. return url
  49. # 收到websocket错误的处理
  50. def on_error(ws, error):
  51. print("### error:", error)
  52. # 收到websocket关闭的处理
  53. def on_close(ws,one,two):
  54. print(" ")
  55. # 收到websocket连接建立的处理
  56. def on_open(ws):
  57. thread.start_new_thread(run, (ws,))
  58. def run(ws, *args):
  59. data = json.dumps(gen_params(appid=ws.appid, domain= ws.domain,question=ws.question))
  60. ws.send(data)
  61. # 收到websocket消息的处理
  62. def on_message(ws, message):
  63. # print(message)
  64. data = json.loads(message)
  65. code = data['header']['code']
  66. if code != 0:
  67. print(f'请求错误: {code}, {data}')
  68. ws.close()
  69. else:
  70. choices = data["payload"]["choices"]
  71. status = choices["status"]
  72. content = choices["text"][0]["content"]
  73. print(content,end ="")
  74. global answer
  75. answer += content
  76. # print(1)
  77. if status == 2:
  78. ws.close()
  79. def gen_params(appid, domain,question):
  80. """
  81. 通过appid和用户的提问来生成请参数
  82. """
  83. data = {
  84. "header": {
  85. "app_id": appid,
  86. "uid": "1234"
  87. },
  88. "parameter": {
  89. "chat": {
  90. "domain": domain,
  91. "random_threshold": 0.5,
  92. "max_tokens": 2048,
  93. "auditing": "default"
  94. }
  95. },
  96. "payload": {
  97. "message": {
  98. "text": question
  99. }
  100. }
  101. }
  102. return data
  103. def main(appid, api_key, api_secret, Spark_url,domain, question):
  104. # print("星火:")
  105. wsParam = Ws_Param(appid, api_key, api_secret, Spark_url)
  106. #websocket.enableTrace(False)
  107. wsUrl = wsParam.create_url()
  108. ws = websocket.WebSocketApp(wsUrl, on_message=on_message, on_error=on_error, on_close=on_close, on_open=on_open)
  109. ws.appid = appid
  110. ws.question = question
  111. ws.domain = domain
  112. ws.run_forever(sslopt={"cert_reqs": ssl.CERT_NONE})

然后下面的三行信息就需要用刚刚自己的API密钥填写:
 

  1. #以下密钥信息从控制台获取
  2. appid = "******" #填写控制台中获取的 APPID 信息
  3. api_secret = "****************" #填写控制台中获取的 APISecret 信息
  4. api_key ="***********************8" #填写控制台中获取的 APIKey 信息
  5. #用于配置大模型版本,默认“general/generalv2”
  6. #domain = "general" # v1.5版本
  7. domain = "generalv2" # v2.0版本
  8. #云端环境的服务地址
  9. #Spark_url = "ws://spark-api.xf-yun.com/v1.1/chat" # v1.5环境的地址
  10. Spark_url = "ws://spark-api.xf-yun.com/v2.1/chat" # v2.0环境的地址
  11. text =[]
  12. # length = 0
  13. def getText(role,content):
  14. jsoncon = {}
  15. jsoncon["role"] = role
  16. jsoncon["content"] = content
  17. text.append(jsoncon)
  18. return text
  19. def getlength(text):
  20. length = 0
  21. for content in text:
  22. temp = content["content"]
  23. leng = len(temp)
  24. length += leng
  25. return length
  26. def checklen(text):
  27. while (getlength(text) > 8000):
  28. del text[0]
  29. return text
  30. if __name__ == '__main__':
  31. text.clear
  32. while(1):
  33. Input = input("\n我:")
  34. question = checklen(getText("user",Input))
  35. answer =""
  36. print("星火:",end = "")
  37. main(appid,api_key,api_secret,Spark_url,domain,question)
  38. getText("assistant",answer)
  39. # print(str(text))

其他完全不用改,直接就能运行了:

 现在就以及能运行了,但是每次都要启动python还是很麻烦,那就把它打包为可执行的程序,这样以后就可以做到随处可用!

(如果有很多文本数据需要进行一一处理,那么使用python循环,然后API回答是最好不过了,比人工聊天一段一段的复制粘贴快很多)


打包程序

主要依靠pyinstaller库实现,安装:

pip install pyinstaller

然后win+r,输入cmd打开终端

输入自己的代码文件所在的路径:

cd /d "E:\Xiao work\其他\自学pandas\脚本系列"

然后输入打包的文件名称,我的文件名叫讯飞星火.py

pyinstaller --onefile 讯飞星火.py

等待就行,后面就可以在这个目录下的dist文件夹里面找到这个程序了。
 

它才5MB,这么小我是没想到的....

双击打开就能用,输入你想说的话:

虽然很简陋.....,但很方便,双击打开就能用,只有要电脑有网就能用,文件也不大。

要是有大佬能加个漂亮的图形互动界面就能成为真正的应用程序了。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/337670
推荐阅读
相关标签
  

闽ICP备14008679号