# -*- 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讯飞语音合成相关推荐

  1. 手把手带你飞Python爬虫+数据清洗新手教程(一)

    本文共有2394字,读完大约需要10分钟. 目录 简介 思考 撸起袖子开始干 1 获取网页源代码 2 在网页源代码里找出所需信息的位置 3 数据清洗 4 完整代码 5 优化后的代码 简介 本文使用An ...

  2. python +飞书 读取飞书EHR的个人信息

    python 读取飞书EHR个人信息 关于飞书,不做过多介绍,毕竟现在太火爆了.以至于下班的时候,在地铁以前看到都是用微信沟通,现在在下班的地铁上,随处可见使用飞书的同学. 最近公司也在使用飞书,打算 ...

  3. 利用腾讯云Python函数实现机场每日自动签到领流量

    利用腾讯云Python函数实现机场每日自动签到领流量 基于项目 https://github.com/zhjc1124/ssr_autocheckin 修改 sspanel自动签到脚本(腾讯云函数) ...

  4. 腾讯课堂Python课程哪家强?

    腾讯课堂Python课程哪家强? 文章目录 腾讯课堂Python课程哪家强? 一.前言 二.数据读取和数据预处理 1.数据读取 2.数据处理 三.有多少人愿意花钱学Python? 四.多少价位的课买的 ...

  5. Python实现飞书机器人定时发送文本、图片等群消息

    工作中会经常遇到监控告警相关问题,监控和告警的目的是要在事中及时发现问题并定位系统问题,那么当系统或平台出现问题了,如何及时暴露这些问题给对应的项目开发人员呢? 本文记录了在Python项目中利用飞书 ...

  6. 利用 Python 打造一个语音合成系统

    作者 | thedaydreamer 来源丨CSDN博客 背景 一直对语音合成系统比较感兴趣,总想能给自己合成一点内容,比如说合成小说,把我下载的电子书播报给我听等等. 语音合成系统 其实就是一个基于 ...

  7. 利用Python打造一个语音合成系统,听说你想要御姐音?

    背景 一直对语音合成系统比较感兴趣,总想能给自己合成一点内容,比如说合成小说,把我下载的电子书播报给我听等等. 语音合成系统 其实就是一个基于语音合成的工具,但是这个东西由于很多厂家都提供了API的形 ...

  8. 利用Python打造一个语音合成系统

    利用Python打造一个语音合成系统 背景 一直对语音合成系统比较感兴趣,总想能给自己合成一点内容,比如说合成小说,把我下载的电子书播报给我听等等. 语音合成系统 其实就是一个基于语音合成的工具,但是 ...

  9. 告警消息何去何从?在飞书中飞起来

    作者简介 袁振,SUSE Rancher 技术支持经理,负责订阅客户售后技术支持团队,为订阅客户提供技术支持服务.2016 年开始接触容器.Kubernetes 技术,对自动化运维.Devops.Ku ...

最新文章

  1. Spring复习笔记:4
  2. cut、grep和排序命令
  3. SQL语言基础:数据库语言概念介绍
  4. 2020计算机网络基础与应用,2020年国防科技大学硕士研究生考试F1107计算机网络基础考试大纲...
  5. (四)nodejs循序渐进-函数,类和对象(基础篇)
  6. hbase hdfs外部表_硬核干货长文!Hbase来了解一下不?
  7. 高效代码审查的十个经验
  8. [C++] - C++11 多线程 - Mutex
  9. 17 java 存在的问题(转)
  10. 扩展的几个应用 发布网络YUM源 vim编辑技巧 源码编译安装 systemctl控制
  11. 计算机网络第七版谢希仁课后答案第三章(部分答案)
  12. 最新网上赚钱方法,这四种最靠谱!
  13. bootstrap框架中的分割线
  14. 埃默里大学有计算机专业吗,埃默里大学计算机专业申请需要满足哪些条件?
  15. Java服务器处理图片上传
  16. mac os 直接打开html文件,macos – 在Mac OS X上打开磁盘设备文件以进行写访问
  17. 用于RF收发器的简单基带处理器详细教程
  18. Python中os.sep的用法
  19. Springboot企业出纳系统的设计与实现7k9je计算机毕业设计-课程设计-期末作业-毕设程序代做
  20. ESP8266-Arduino编程实例-2.8寸TFT LCD驱动(ILI9341控制器)

热门文章

  1. 《C语言程序设计》单元总结与练习题
  2. IDEA中修改项目与Moudle名称方法总结
  3. 蚁群算法C语言最短路径规划,蚁群算法规划路径
  4. netty4 io.netty.util.IllegalReferenceCountException: refCnt: 0, decrement: 1
  5. 湖北商贸学院计算机二级领取,湖北商贸学院教务管理系统入口http://jw.hbc.edu.cn/...
  6. MIUI9开发版提前完成全系机型适配,近50款小米手机可升级
  7. windows系统使用的那点事(1)-解决win10的EN输入法不见了
  8. Sublime Text3中文版下载网址
  9. 信息3.0 ,让机器完成熵增中的有序
  10. C语言源程序作业完成系统,C语言源程序的自动评判系统