1,语音的合成,识别

后端代码:

from aip import AipSpeech, AipNlp
import os
# 语音合成
""" 你的 APPID AK SK """
# 申请的Ai.baidu.com的ID,接口,密钥
APP_ID = '15217709'
API_KEY = 'eNiP5QUsgBh6QwpbNv8Qmsy3'
SECRET_KEY = 'gwhM3wDo0Kjjd1PDIxqqW4Bfex10Y4f3' # 实例化AipSpeech,AipNlp对象
client = AipSpeech(APP_ID, API_KEY, SECRET_KEY)
nlp_client = AipNlp(APP_ID, API_KEY, SECRET_KEY) # 调节发音的会泽的
# 第一个可以放要转化吃那个语音的文字
result = client.synthesis('', 'zh', 1, {
"per": 4, # 表示是男音还是女音
"spd": 8, # 表示说话的速度
"pit": 6,
"vol": 5,
}) # 识别正确返回语音二进制 错误则返回dict ,这时返回的是文件文本
if not isinstance(result, dict):
with open('auido.mp3', 'wb') as f:
f.write(result) # 把二进制语音写入到文件中 # 定义一个读取文件的函数
def get_file_content(filePath):
# 把wma格式的文件转化为.pcm格式的文件
os.system(f"ffmpeg -y -i {filePath} -acodec pcm_s16le -f s16le -ac 1 -ar 16000 {filePath}.wma.pcm")
# 把转化了的格式保存到当前目录
with open(f"{filePath}.wma.pcm", 'rb') as fp:
# 返回这个文件读取的内容
return fp.read() # 并把这个文件返回给调用者 # get_file_content("cg.m4a")
# 识别本地文件, 把本地的语音文件转成pcm个格式的文件并把语音转化成二进制文件
res = client.asr(get_file_content('xh.m4a'), 'pcm', 16000, {
'dev_pid': 1536,
})
print(res, type(res))
# {'corpus_no': '6637053740205578210', 'err_msg': 'success.', 'err_no': 0, 'result': ['给我讲个笑话'], 'sn': '757488757051545309494'}, <class 'dict'> Q = res.get("result")[0]
# 取到输入的主要内容
print(1,Q) # 1 给我讲个笑话
# 判断是不是问的是名字,是拿Q和"你叫什么"做相似度匹配如果大于0.7,则表明用户表达的是这个意思
if nlp_client.simnet(Q, "你叫什么?").get("score") >= 0.7:
A = "我的名字叫雪雪"
result = client.synthesis(A, "zh", 1, {
"per": 4,
"pit": 8,
"spd": 4,
"vol": 5,
})
# 如果不存在result,就打开audio.mp3的文件
if not isinstance(result, dict):
with open("audio.mp3", "wb") as f:
f.write(result)
os.system("audio.mp3") else:
# 调用图灵机器人
import go_tuling
# 传2个参数,一个是用户输入的内容,并赋值给A
A = go_tuling.tl(Q, "asd")
# 结果赋值给result,并读取这个文件
result = client.synthesis(A, "zh", 1, {
"per": 4,
"pit": 8,
"spd": 4,
"vol": 5,
})
if not isinstance(result, dict):
with open("audio.mp3", "wb") as f:
f.write(result) os.system("audio.mp3")

调用图灵的代码:

import requests

url = "http://openapi.tuling123.com/openapi/api/v2"

data_dict = {
"reqType": 0,
"perception": {
"inputText": {
"text": "北京"
},
},
"userInfo": {
"apiKey": "96dfe320eec549519c5168093f93b2dc",
"userId": "asd",
}
} def tl(text, uid):
# 给字典赋值text,这个text是传过来的用户输入的内容
data_dict["perception"]["inputText"]["text"] = text
# 并给字典赋值是哪个用户的要求
data_dict["userInfo"]["userInfo"] = uid
# 把这个消息数据反送给图灵
res = requests.post(url, json=data_dict)
# 会得到一个响应值,去json的方法
res_json = res.json()
print("res:", res, type(res))
# res: <Response [200]> <class 'requests.models.Response'>
print("res_json:", res_json,type(res_json))
# res_json: {'intent': {'actionName': '', 'code': 10006, 'intentName': ''}, 'results': [{'groupType': 1, 'resultType': 'text', 'values': {'text': '猪猪与爸爸 小猪与爸爸在谈话小猪说:爸爸为什么上个月有人来要钱你说没有,这个月那个人来要钱你说又没有?小猪爸爸:哎呀,爸爸要讲信用嘛!'}}]} <class 'dict'>
# 返回图灵相应的数据
return res_json.get("results")[0]["values"]["text"]

百度AI的语音合成,语音识别的更多相关文章

  1. 百度ai 基于node 语音识别 音频文件类型转换

    百度ai 基于node 语音识别 音频文件类型转换 项目简介 源代码移步:https://github.com/xuess/ai-baidu-node 本项目主要功能为,本地音频语音识别和文件类型转换 ...

  2. 百度AI开放平台,语音识别,语音合成以及短文本相似度

    百度AI开放平台:https://ai.baidu.com/ 语音合成 from aip import AipSpeech APP_ID=" #'你的 App ID' API_KEY=&qu ...

  3. 基于Flask和百度AI实现与机器人对话

    实现对话机器人主要有个步骤 : 一.前端收集语音传入后端 二.后端基于百度AI接口进行语音识别,转换成文字 三.对文字进行自定义验证或通过图灵端口进行处理,生成回复内容 四.将文字通过百度AI接口合成 ...

  4. 基于百度AI开放平台的人脸识别及语音合成

    基于百度AI的人脸识别及语音合成课题 课题需求 (1)人脸识别 在Web界面上传人的照片,后台使用Java技术接收图片,然后对图片进行解码,调用云平台接口识别人脸特征,接收平台返回的人员年龄.性别.颜 ...

  5. ros下基于百度语音的,语音识别和语音合成

    代码地址如下:http://www.demodashi.com/demo/13153.html 概述: 本demo是ros下基于百度语音的,语音识别和语音合成,能够实现文字转语音,语音转文字的功能. ...

  6. 什么?小程序实时语音识别你还在痛苦的对接科大讯飞?百度Ai识别?

    前言 微信小程序,说不上大火,但是需求还是不少的.各大企业都想插一足 于是前端同学就有事情做了. 需求 我需要录音 我边说话边识别,我要同声传译,我要文字转语音,还要萝莉音 我:??? 正文 一开始, ...

  7. 人工智能-调百度AI接口+图灵机器人

    1.登陆百度AI的官网 1.注册:没有账号注册 2.创建应用 3.创建应用 4.查看应用的ID 5.Python代码 from aip import AipSpeech APP_ID = " ...

  8. python 全栈开发,Day122(人工智能初识,百度AI)

    一.人工智能初识 什么是智能? 我们通常把人成为智慧生物,那么”智慧生物的能力”就是所谓的”智能”我们有什么能力?听,说,看,理解,思考,情感等等 什么是人工智能? 顾名思义就是由人创造的”智慧能力” ...

  9. 使用百度ai接口加图灵机器人完成简单web版语音对话

    app文件 from flask import Flask, request, render_template, jsonify, send_file from uuid import uuid4 i ...

随机推荐

  1. tiny4412u-boot烧写及根文件系统制作(不进入终端问题)

    http://m.blog.csdn.net/article/details?id=51400196(转) VMware12 环境:ubuntu12.4 开发板:tiny4412 首先烧写bootlo ...

  2. 基于selenium爬取拉勾网职位信息

    1.selenium Selenium 本是一个用于Web应用程序测试的工具.Selenium测试直接运行在浏览器中,就像真正的用户在操作一样.而这一特性为爬虫开发提供了一个选择及方向,由于其本身依赖 ...

  3. CUDA & cuDNN环境配置

    环境 python3.5 tensorflow 1.3 VUDA  8.0 cuDNN V6.0 1.确保GPU驱动已经安装 lspci | grep -i nvidia 通过此命令可以查看GPU信息 ...

  4. 稳定排序(sort+结构体)

    #include<cstdio> #include<algorithm> #include<string.h> using namespace std; struc ...

  5. 收集Windows 8 Metro UI 风格网站资源,觉得不错的顶啊!!

    这些资源包含:模板,框架,jQuery插件,图标集等.帮助你快速开发Windows 8 Metro UI风格的网站.本文转自虾米站长网 Frameworks & Templates For M ...

  6. python012 Python3 编程第一步

    Python3 编程第一步在前面的教程中我们已经学习了一些 Python3 的基本语法知识,下面我们尝试来写一个斐波纳契数列.实例如下: #!/usr/bin/python3 # Fibonacci ...

  7. 以太坊和IPFS如何存储数据

    如何将JSON文件存储在IPFS上,并使用Oraclize访问智能合约中的数据呢? 以太坊是一个成熟的区块链,使开发人员能够创建智能合约,在区块链上执行的程序可以由交易触发.人们经常将区块链称为数据库 ...

  8. Ubuntu启用IPv6上google的方法

    Pv6就是我们通常所说的互联网协议,是TCP/IP的核心协议,那么在Linux下如何开启IPv6呢?下面以Ubuntu为例,给大家介绍下Ubuntu启用IPv6的方法. 方法: $sudo apt-g ...

  9. 【BZOJ3626】LCA(树上差分,树链剖分)

    题意:给出一个n个节点的有根树(编号为0到n-1,根节点为0).一个点的深度定义为这个节点到根的距离+1.设dep[i]表示点i的深度,LCA(i,j)表示i与j的最近公共祖先.有q次询问,每次询问给 ...

  10. POJ3233:Matrix Power Series

    对n<=30(其实可以100)大小的矩阵A求A^1+A^2+……+A^K,K<=1e9,A中的数%m. 从K的二进制位入手.K分解二进制,比如10110,令F[i]=A^1+A^2+……+ ...