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

这篇具有很好参考价值的文章主要介绍了手把手教你打造自己的AI聊天机器人程序(讯飞星火API)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

案例背景

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

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

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

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


申请准备

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

然后点击api测试

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

 然后点击申请:
手把手教你打造自己的AI聊天机器人程序(讯飞星火API),chatgpt,python,科大讯飞,讯飞星火

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

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

全部都填好:

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

之后就能得到一个APPID:

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

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

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

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


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

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

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

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

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

点击我们申请的应用:

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

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

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

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

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


编写代码

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

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

首先要装一个库,websocket  和 websocket_client

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

pip install websocket

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

然后再安装:

pip install websocket_client

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

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

import _thread as thread
import base64
import datetime
import hashlib
import hmac
import json
from urllib.parse import urlparse
import ssl
from datetime import datetime
from time import mktime
from urllib.parse import urlencode
from wsgiref.handlers import format_date_time

import websocket  # 使用websocket_client
answer = ""

class Ws_Param(object):
    # 初始化
    def __init__(self, APPID, APIKey, APISecret, Spark_url):
        self.APPID = APPID
        self.APIKey = APIKey
        self.APISecret = APISecret
        self.host = urlparse(Spark_url).netloc
        self.path = urlparse(Spark_url).path
        self.Spark_url = Spark_url

    # 生成url
    def create_url(self):
        # 生成RFC1123格式的时间戳
        now = datetime.now()
        date = format_date_time(mktime(now.timetuple()))

        # 拼接字符串
        signature_origin = "host: " + self.host + "\n"
        signature_origin += "date: " + date + "\n"
        signature_origin += "GET " + self.path + " HTTP/1.1"

        # 进行hmac-sha256进行加密
        signature_sha = hmac.new(self.APISecret.encode('utf-8'), signature_origin.encode('utf-8'),
                                 digestmod=hashlib.sha256).digest()

        signature_sha_base64 = base64.b64encode(signature_sha).decode(encoding='utf-8')

        authorization_origin = f'api_key="{self.APIKey}", algorithm="hmac-sha256", headers="host date request-line", signature="{signature_sha_base64}"'

        authorization = base64.b64encode(authorization_origin.encode('utf-8')).decode(encoding='utf-8')

        # 将请求的鉴权参数组合为字典
        v = {
            "authorization": authorization,
            "date": date,
            "host": self.host
        }
        # 拼接鉴权参数,生成url
        url = self.Spark_url + '?' + urlencode(v)
        # 此处打印出建立连接时候的url,参考本demo的时候可取消上方打印的注释,比对相同参数时生成的url与自己代码生成的url是否一致
        return url


# 收到websocket错误的处理
def on_error(ws, error):
    print("### error:", error)


# 收到websocket关闭的处理
def on_close(ws,one,two):
    print(" ")


# 收到websocket连接建立的处理
def on_open(ws):
    thread.start_new_thread(run, (ws,))


def run(ws, *args):
    data = json.dumps(gen_params(appid=ws.appid, domain= ws.domain,question=ws.question))
    ws.send(data)


# 收到websocket消息的处理
def on_message(ws, message):
    # print(message)
    data = json.loads(message)
    code = data['header']['code']
    if code != 0:
        print(f'请求错误: {code}, {data}')
        ws.close()
    else:
        choices = data["payload"]["choices"]
        status = choices["status"]
        content = choices["text"][0]["content"]
        print(content,end ="")
        global answer
        answer += content
        # print(1)
        if status == 2:
            ws.close()


def gen_params(appid, domain,question):
    """
    通过appid和用户的提问来生成请参数
    """
    data = {
        "header": {
            "app_id": appid,
            "uid": "1234"
        },
        "parameter": {
            "chat": {
                "domain": domain,
                "random_threshold": 0.5,
                "max_tokens": 2048,
                "auditing": "default"
            }
        },
        "payload": {
            "message": {
                "text": question
            }
        }
    }
    return data


def main(appid, api_key, api_secret, Spark_url,domain, question):
    # print("星火:")
    wsParam = Ws_Param(appid, api_key, api_secret, Spark_url)
    #websocket.enableTrace(False)
    wsUrl = wsParam.create_url()
    ws = websocket.WebSocketApp(wsUrl, on_message=on_message, on_error=on_error, on_close=on_close, on_open=on_open)
    ws.appid = appid
    ws.question = question
    ws.domain = domain
    ws.run_forever(sslopt={"cert_reqs": ssl.CERT_NONE})

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

#以下密钥信息从控制台获取
appid = "******"     #填写控制台中获取的 APPID 信息
api_secret = "****************"   #填写控制台中获取的 APISecret 信息
api_key ="***********************8"    #填写控制台中获取的 APIKey 信息

#用于配置大模型版本,默认“general/generalv2”
#domain = "general"   # v1.5版本
domain = "generalv2"    # v2.0版本
#云端环境的服务地址
#Spark_url = "ws://spark-api.xf-yun.com/v1.1/chat"  # v1.5环境的地址
Spark_url = "ws://spark-api.xf-yun.com/v2.1/chat"  # v2.0环境的地址


text =[]

# length = 0

def getText(role,content):
    jsoncon = {}
    jsoncon["role"] = role
    jsoncon["content"] = content
    text.append(jsoncon)
    return text

def getlength(text):
    length = 0
    for content in text:
        temp = content["content"]
        leng = len(temp)
        length += leng
    return length

def checklen(text):
    while (getlength(text) > 8000):
        del text[0]
    return text
    


if __name__ == '__main__':
    text.clear
    while(1):
        Input = input("\n我:")
        question = checklen(getText("user",Input))
        answer =""
        print("星火:",end = "")
        main(appid,api_key,api_secret,Spark_url,domain,question)
        getText("assistant",answer)
        # print(str(text))

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

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

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

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


打包程序

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

pip install pyinstaller

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

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

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

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

pyinstaller --onefile 讯飞星火.py

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

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

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

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

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

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

要是有大佬能加个漂亮的图形互动界面就能成为真正的应用程序了。文章来源地址https://www.toymoban.com/news/detail-717277.html

到了这里,关于手把手教你打造自己的AI聊天机器人程序(讯飞星火API)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 手把手教你部署AutoGPT,30分钟拥有自己的AI助手!

    如果不想往下看了,那就直接 点我。 AutoGPT是由GPT-4驱动的开源应用程序,可以自主实现用户设定的任务目标;从AutoGPT开始,AI将可以自主地提出计划,然后执行计划;还具有互联网访问、长期和短期内存管理、用于文本生成的GPT-4实例以及使用GPT-3.5进行文件存储和生成摘要

    2024年02月05日
    浏览(62)
  • 手把手教你怎么搭建自己的AI数字人直播间?帮你24小时不间断直播卖货

    在搭建AI数字人直播间之前,您需要了解数字人技术。 数字人是一种由人工智能技术构建的虚拟人物,其外貌、行为、语言等特征与真实人物相似,可以与人进行互动。数字人可以通过语音合成、人脸识别、情感识别等技术来实现与观众的交互。数字人直播间是使用现有的技

    2024年02月05日
    浏览(200)
  • 只需四步,手把手教你打造专属数字人

    伴随ChatGPT的问世,在技术与商业运作上都日渐发展成熟的数字人产业正持续升温。去年9月,北京市发布了国内首个数字人产业专项支持政策,提出将依托国家文化专网将数字人纳入文化数据服务平台。以数字人、ChatGPT为代表的互联网3.0创新应用产业机遇正迎面而来,美摄数

    2024年02月08日
    浏览(79)
  • 手把手自己制作一个飞书机器人

    飞书机器人 如果你想添加新的对话逻辑,你只需要在 ChatApi.py 中添加新的if条件判断语句即可。如果你能开发出新功能,请在仓库中提出Pull requests合并请求,我将感激不尽! 2023年9月1日更新 更新了对话机器人返回帮助界面功能,用户发送“帮助”,返回机器人使用说明 20

    2024年02月03日
    浏览(138)
  • 手把手教你搭建自己本地的ChatGLM

    如果能够本地自己搭建一个ChatGPT的话,训练一个属于自己知识库体系的人工智能AI对话系统,那么能够高效的处理应对所属领域的专业知识,甚至加入职业思维的意识,训练出能够结合行业领域知识高效产出的AI。这必定是十分高效的生产力工具,且本地部署能够保护个人数

    2024年02月03日
    浏览(73)
  • 手把手教你使用Segformer训练自己的数据

    使用Transformer进行语义分割的简单高效设计。 将 Transformer 与轻量级多层感知 (MLP) 解码器相结合,表现SOTA!性能优于SETR、Auto-Deeplab和OCRNet等网络 相比于ViT,Swin Transfomer计算复杂度大幅度降低,具有输入图像大小线性计算复杂度。Swin Transformer随着深度加深,逐渐合并图像块来

    2024年01月20日
    浏览(75)
  • hMailServer 使用教程 —— 手把手教你搭建自己的邮箱服务器

    前言 假设你已经拥有了一台具有 公网ip 的服务器,以及 域名 hMailServer 介绍 hMailServer 适用于 Windows 操作系统,它除了提供邮箱系统需要的所有基础功能之外,还内置了一些常用功能,比如:反垃圾邮件、反病毒邮件,而其他未内置的功能,则可以根据用户需要,自行去社区

    2024年02月04日
    浏览(68)
  • 手把手教你如何拥有自己的git仓库(国内版码云)

    码云(Gitee)简介:   码云(Gitee)是 开源中国社区推出的代码托管协作开发平台,支持Git,提供免费的私有仓库托管 。Gitee目前已经成为国内最大的代码托管平台。帮助开发者存储和管理其项目源代码,且能够追踪、记录并控制用户对其代码的修改,提供稳定、高效、安

    2024年02月15日
    浏览(76)
  • 手把手教你如何使用YOLOV5训练自己的数据集

    YOLOV5是目前最火热的目标检测算法之一。YOLOV5为一阶段检测算法因此它的速度非常之快。可以在复杂场景中达到60祯的实时检测频率。 接下来本文将详细的讲述如何使用YOLOV5去训练自己的数据集 YOLOV5中使用了Tensorboard和Wandb来可视化训练,其中Wandb配置可以看这篇文章: Wand

    2024年02月05日
    浏览(69)
  • 手把手教你如何使用SpringBoot3打造一个个性化的代码生成器

    代码基于SpringBoot3、Vue3、highlight实现自定义代码生成功能 SpringBoot3.x、MySQL8、MyBatisPlus3.5.x、velocity2.x、SpringSecurity6.x、Vue3、TypeScript、highlight demo所需要的依赖及其对应版本号 pom 配置文件 这里是最基础的MySQL的配置信息 application 1.1、代码生成器源码目录 这里是代码生成器的源

    2024年01月19日
    浏览(61)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包