python调用百度REST API实现语音识别


Posted in Python onAugust 30, 2018

目前,语音识别,即将语音内容转换为文字的技术已经比较成熟,遥想当时锤子发布会上展示的讯飞输入法语音识别,着实让讯飞火了一把。由于此类语音识别需要采集大量的样本,才能达到一定的准确度,个人很难从零开始搭建。但是,许多拥有语音识别技术的公司,或多或少会提供一些API或者SDK供开发者使用,这样就把语音识别的门槛降到了一个很低的程度,只需几行代码即可实现。下面我介绍以下如何使用Python调用百度的REST API实现一个简单的语音识别。

注册账号,并成为开发者

打开 http://yuyin.baidu.com/ ,并且使用你的百度账号登陆,如果你不是开发者,系统会自动引导你申请成为开发者。

创建应用

打开 http://yuyin.baidu.com/app ,点击创建应用,应用名称自己取,选择合适的应用类型。下一步,服务类型选择语音识别,继续点击下一步,然后就可以关闭了。

刷新当前页面,你就可以看到自己创建的应用,点击查看key,这些是进行身份识别的关键信息。

代码编写

在 http://yuyin.baidu.com/docs/asr/54 可以查看官方文档,百度提供了两种方法:隐式发送是将音频数据打包转换成一个字符串,放到json数据包中来发送;显示发送则是直接发送语音数据。本代码使用隐式发送。

注意:使用前要将你的应用信息填入适当位置

#!/usr/bin/env python
# coding: utf-8
import urllib2
import json
import base64
import os

#设置应用信息
baidu_server = "https://openapi.baidu.com/oauth/2.0/token?"
grant_type = "client_credentials"
client_id = "" #填写API Key
client_secret = "" #填写Secret Key

#合成请求token的URL
url = baidu_server+"grant_type="+grant_type+"&client_id="+client_id+"&client_secret="+client_secret

#获取token
res = urllib2.urlopen(url).read()
data = json.loads(res)
token = data["access_token"]
print token

#设置音频属性,根据百度的要求,采样率必须为8000,压缩格式支持pcm(不压缩)、wav、opus、speex、amr
VOICE_RATE = 8000
WAVE_FILE = "test.wav" #音频文件的路径
USER_ID = "hail_hydra" #用于标识的ID,可以随意设置
WAVE_TYPE = "wav"

#打开音频文件,并进行编码
f = open(WAVE_FILE, "r")
speech = base64.b64encode(f.read())
size = os.path.getsize(WAVE_FILE)
update = json.dumps({"format":WAVE_TYPE, "rate":VOICE_RATE, 'channel':1,'cuid':USER_ID,'token':token,'speech':speech,'len':size})
headers = { 'Content-Type' : 'application/json' } 
url = "http://vop.baidu.com/server_api"
req = urllib2.Request(url, update, headers)

r = urllib2.urlopen(req)


t = r.read()
result = json.loads(t)
print result
if result['err_msg']=='success.':
  word = result['result'][0].encode('utf-8')
  if word!='':
    if word[len(word)-3:len(word)]==',':
      print word[0:len(word)-3]
    else:
      print word
  else:
    print "音频文件不存在或格式错误"
else:
  print "错误"

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
图文讲解选择排序算法的原理及在Python中的实现
May 04 Python
LRUCache的实现原理及利用python实现的方法
Nov 21 Python
python3.6连接MySQL和表的创建与删除实例代码
Dec 28 Python
Python实现的凯撒密码算法示例
Apr 12 Python
对sklearn的使用之数据集的拆分与训练详解(python3.6)
Dec 14 Python
python接口自动化(十六)--参数关联接口后传(详解)
Apr 16 Python
基于Python的图像数据增强Data Augmentation解析
Aug 13 Python
Python3将jpg转为pdf文件的方法示例
Dec 13 Python
Django模板标签{% for %}循环,获取制定条数据实例
May 14 Python
解决redis与Python交互取出来的是bytes类型的问题
Jul 16 Python
opencv-python图像配准(匹配和叠加)的实现
Jun 23 Python
用python基于appium模块开发一个自动收取能量的小助手
Sep 25 Python
python调用百度语音REST API
Aug 30 #Python
python调用百度语音识别api
Aug 30 #Python
python实现ID3决策树算法
Aug 29 #Python
python实现C4.5决策树算法
Aug 29 #Python
python机器学习之KNN分类算法
Aug 29 #Python
深入理解python中sort()与sorted()的区别
Aug 29 #Python
Python实现拷贝/删除文件夹的方法详解
Aug 29 #Python
You might like
一个php作的文本留言本的例子(五)
2006/10/09 PHP
ThinkPHP3.1新特性之查询条件预处理简介
2014/06/19 PHP
thinkphp常见路径用法分析
2014/12/02 PHP
PHP生成唯一订单号的方法汇总
2015/04/16 PHP
php使用for语句输出三角形的方法
2015/06/09 PHP
javaScript parseInt字符转化为数字函数使用小结
2009/11/05 Javascript
一个页面元素appendchild追加到另一个页面元素的问题
2013/01/27 Javascript
jsonp原理及使用
2013/10/28 Javascript
Javascript函数式编程语言
2015/10/11 Javascript
为何JS操作的href都是javascript:void(0);呢
2015/11/12 Javascript
JS当前页面登录注册框,固定DIV,底层阴影的实例代码
2016/09/29 Javascript
vue实现页面加载动画效果
2017/09/19 Javascript
JavaScript实现鼠标滚轮控制页面图片切换功能示例
2017/10/14 Javascript
nodejs超出最大的调用栈错误问题
2017/12/27 NodeJs
微信小程序使用字体图标的方法
2019/05/23 Javascript
详解小程序如何改变onLoad的执行时机
2019/11/01 Javascript
微信小程序关键字变色实现代码实例
2019/12/13 Javascript
Python实现曲线点抽稀算法的示例
2017/10/12 Python
十行代码使用Python写一个USB病毒
2019/06/21 Python
python实现列表的排序方法分享
2019/07/01 Python
Django 用户认证组件使用详解
2019/07/23 Python
python GUI库图形界面开发之PyQt5状态栏控件QStatusBar详细使用方法实例
2020/02/28 Python
Python如何读取、写入CSV数据
2020/07/28 Python
PyCharm2019.3永久激活破解详细图文教程,亲测可用(不定期更新)
2020/10/29 Python
python 制作本地应用搜索工具
2021/02/27 Python
肯尼亚网上商城:Kilimall
2016/08/20 全球购物
GLAMGLOW格莱魅美国官网:美国知名的面膜品牌
2016/12/31 全球购物
Myprotein比利时官方网站:欧洲第一运动营养品牌
2020/10/04 全球购物
办公室秘书自我鉴定
2014/01/18 职场文书
2015年乡镇平安建设工作总结
2015/05/13 职场文书
运动会200米广播稿
2015/08/19 职场文书
观看安全警示教育片心得体会
2016/01/15 职场文书
关于拾金不昧的感谢信(五篇)
2019/10/18 职场文书
Mysql MVCC机制原理详解
2021/04/20 MySQL
Python 可迭代对象 iterable的具体使用
2021/08/07 Python
使用vue判断当前环境是安卓还是IOS
2022/04/12 Vue.js