html语音合成text2audio讯飞,python讯飞语音合成
# -*- coding:utf-8 -*-
#
# author: iflytek
#
# 本demo测试时运行的环境为:Windows + Python3.7
# 本demo测试成功运行时所安装的第三方库及其版本如下:
# cffi==1.12.3
# gevent==1.4.0
# greenlet==0.4.15
# pycparser==2.19
# six==1.12.0
# websocket==0.2.1
# websocket-client==0.56.0
#
# 错误码链接:https://www.xfyun.cn/document/error-code (code返回错误码时必看)
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
import websocket
import datetime
import hashlib
import base64
import hmac
import json
from urllib.parse import urlencode
import time
import ssl
from wsgiref.handlers import format_date_time
from datetime import datetime
from time import mktime
import _thread as thread
import os
ws=None
STATUS_FIRST_FRAME = 0 # 第一帧的标识
STATUS_CONTINUE_FRAME = 1 # 中间帧标识
STATUS_LAST_FRAME = 2 # 最后一帧的标识
class Ws_Param(object):
# 初始化
def __init__(self, APPID, APIKey, APISecret, Text):
self.APPID = APPID
self.APIKey = APIKey
self.APISecret = APISecret
self.Text = Text
# 公共参数(common)
self.CommonArgs = {"app_id": self.APPID}
# 业务参数(business),更多个性化参数可在官网查看
self.BusinessArgs = {"aue": "raw",
"auf": "audio/L16;rate=16000",
"vcn": "aisjiuxu",
"tte": "utf8"}
self.Data = {"status": 2, "text": str(base64.b64encode(self.Text.encode('utf-8')), "UTF8")}
# 生成url
def create_url(self):
url = 'wss://tts-api.xfyun.cn/v2/tts'
# 生成RFC1123格式的时间戳
now = datetime.now()
date = format_date_time(mktime(now.timetuple()))
# 拼接字符串
signature_origin = "host: " + "ws-api.xfyun.cn" + "\n"
signature_origin += "date: " + date + "\n"
signature_origin += "GET " + "/v2/tts " + "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.b64encode(signature_sha).decode(encoding='utf-8')
authorization_origin = "api_key=\"%s\", algorithm=\"%s\", headers=\"%s\", signature=\"%s\"" % (
self.APIKey, "hmac-sha256", "host date request-line", signature_sha)
authorization = base64.b64encode(authorization_origin.encode('utf-8')).decode(encoding='utf-8')
# 将请求的鉴权参数组合为字典
v = {
"authorization": authorization,
"date": date,
"host": "ws-api.xfyun.cn"
}
# 拼接鉴权参数,生成url
url = url + '?' + urlencode(v)
# print("date: ",date)
# print("v: ",v)
# 此处打印出建立连接时候的url,参考本demo的时候可取消上方打印的注释,比对相同参数时生成的url与自己代码生成的url是否一致
# print('websocket url :', url)
return url
def on_message(ws, message):
try:
message =json.loads(message)
code = message["code"]
sid = message["sid"]
audio = message["data"]["audio"]
audio = base64.b64decode(audio)
status = message["data"]["status"]
if status == 2:
print("ws is closed")
ws.close()
if code != 0:
errMsg = message["message"]
print("sid:%s call error:%s code is:%s" % (sid, errMsg, code))
else:
with open('./demo.pcm', 'ab') as f:
f.write(audio)
cmd='ffmpeg -y -f s16be -ac 1 -ar 16000 -acodec pcm_s16le -i demo.pcm new_mp3.mp3'
import subprocess
subprocess.run(cmd)
# if status==2:
# print("ws is closed******")
# ws.close()
except Exception as e:
print("receive msg,but parse exception:", e)
# 收到websocket错误的处理
def on_error(ws, error):
# import time
# time.sleep(2)
print("### error:",ws)
print("### error:", error)
# 收到websocket关闭的处理
def on_close(ws):
print(ws)
print("### closed ###")
# 收到websocket连接建立的处理
def on_open(ws):
def run(*args):
d = {"common": wsParam.CommonArgs,
"business": wsParam.BusinessArgs,
"data": wsParam.Data,
}
d = json.dumps(d)
print("------>开始发送文本数据")
ws.send(d)
if os.path.exists('./demo.pcm'):
os.remove('./demo.pcm')
# time.sleep(2)
# ws.close()
thread.start_new_thread(run, ())
# run()
if __name__ == "__main__":
# 测试时候在此处正确填写相关信息即可运行
wsParam = Ws_Param(APPID='....', APIKey='.....',
APISecret='.....',
Text="请到控制台添加试用或购买发音人,添加后即显示发音人参数值")
websocket.enableTrace(False)
wsUrl = wsParam.create_url()
ws = websocket.WebSocketApp(wsUrl,
on_message=on_message,
on_error=on_error,
on_close=on_close)
ws.on_open = on_open
ws.run_forever(sslopt={"cert_reqs": ssl.CERT_NONE})
# ws.close()
html语音合成text2audio讯飞,python讯飞语音合成相关推荐
- 手把手带你飞Python爬虫+数据清洗新手教程(一)
本文共有2394字,读完大约需要10分钟. 目录 简介 思考 撸起袖子开始干 1 获取网页源代码 2 在网页源代码里找出所需信息的位置 3 数据清洗 4 完整代码 5 优化后的代码 简介 本文使用An ...
- python +飞书 读取飞书EHR的个人信息
python 读取飞书EHR个人信息 关于飞书,不做过多介绍,毕竟现在太火爆了.以至于下班的时候,在地铁以前看到都是用微信沟通,现在在下班的地铁上,随处可见使用飞书的同学. 最近公司也在使用飞书,打算 ...
- 利用腾讯云Python函数实现机场每日自动签到领流量
利用腾讯云Python函数实现机场每日自动签到领流量 基于项目 https://github.com/zhjc1124/ssr_autocheckin 修改 sspanel自动签到脚本(腾讯云函数) ...
- 腾讯课堂Python课程哪家强?
腾讯课堂Python课程哪家强? 文章目录 腾讯课堂Python课程哪家强? 一.前言 二.数据读取和数据预处理 1.数据读取 2.数据处理 三.有多少人愿意花钱学Python? 四.多少价位的课买的 ...
- Python实现飞书机器人定时发送文本、图片等群消息
工作中会经常遇到监控告警相关问题,监控和告警的目的是要在事中及时发现问题并定位系统问题,那么当系统或平台出现问题了,如何及时暴露这些问题给对应的项目开发人员呢? 本文记录了在Python项目中利用飞书 ...
- 利用 Python 打造一个语音合成系统
作者 | thedaydreamer 来源丨CSDN博客 背景 一直对语音合成系统比较感兴趣,总想能给自己合成一点内容,比如说合成小说,把我下载的电子书播报给我听等等. 语音合成系统 其实就是一个基于 ...
- 利用Python打造一个语音合成系统,听说你想要御姐音?
背景 一直对语音合成系统比较感兴趣,总想能给自己合成一点内容,比如说合成小说,把我下载的电子书播报给我听等等. 语音合成系统 其实就是一个基于语音合成的工具,但是这个东西由于很多厂家都提供了API的形 ...
- 利用Python打造一个语音合成系统
利用Python打造一个语音合成系统 背景 一直对语音合成系统比较感兴趣,总想能给自己合成一点内容,比如说合成小说,把我下载的电子书播报给我听等等. 语音合成系统 其实就是一个基于语音合成的工具,但是 ...
- 告警消息何去何从?在飞书中飞起来
作者简介 袁振,SUSE Rancher 技术支持经理,负责订阅客户售后技术支持团队,为订阅客户提供技术支持服务.2016 年开始接触容器.Kubernetes 技术,对自动化运维.Devops.Ku ...
最新文章
- Spring复习笔记:4
- cut、grep和排序命令
- SQL语言基础:数据库语言概念介绍
- 2020计算机网络基础与应用,2020年国防科技大学硕士研究生考试F1107计算机网络基础考试大纲...
- (四)nodejs循序渐进-函数,类和对象(基础篇)
- hbase hdfs外部表_硬核干货长文!Hbase来了解一下不?
- 高效代码审查的十个经验
- [C++] - C++11 多线程 - Mutex
- 17 java 存在的问题(转)
- 扩展的几个应用 发布网络YUM源 vim编辑技巧 源码编译安装 systemctl控制
- 计算机网络第七版谢希仁课后答案第三章(部分答案)
- 最新网上赚钱方法,这四种最靠谱!
- bootstrap框架中的分割线
- 埃默里大学有计算机专业吗,埃默里大学计算机专业申请需要满足哪些条件?
- Java服务器处理图片上传
- mac os 直接打开html文件,macos – 在Mac OS X上打开磁盘设备文件以进行写访问
- 用于RF收发器的简单基带处理器详细教程
- Python中os.sep的用法
- Springboot企业出纳系统的设计与实现7k9je计算机毕业设计-课程设计-期末作业-毕设程序代做
- ESP8266-Arduino编程实例-2.8寸TFT LCD驱动(ILI9341控制器)
热门文章
- 《C语言程序设计》单元总结与练习题
- IDEA中修改项目与Moudle名称方法总结
- 蚁群算法C语言最短路径规划,蚁群算法规划路径
- netty4 io.netty.util.IllegalReferenceCountException: refCnt: 0, decrement: 1
- 湖北商贸学院计算机二级领取,湖北商贸学院教务管理系统入口http://jw.hbc.edu.cn/...
- MIUI9开发版提前完成全系机型适配,近50款小米手机可升级
- windows系统使用的那点事(1)-解决win10的EN输入法不见了
- Sublime Text3中文版下载网址
- 信息3.0 ,让机器完成熵增中的有序
- C语言源程序作业完成系统,C语言源程序的自动评判系统