一液茎、材料準備
1、樹莓派一個
2乔妈、免驅(qū)動USB麥克風
3蝙云、耳機
二、教程開始
1.錄音
插上麥克風
我用到的是使用了arecord* 測試是否麥克風能否使用路召。
使用錄音輸入如下命令
arecord -D "plughw:1" -f S16_LE -r 16000 -d 3 /home/pi/Desktop/voice.wav
2.語音識別
建立語音識別文件夾輸入如下程序
sudo nano yuyinshibie.py
去百度語音官網(wǎng)申請語音識別
寫代碼進去 將上面申請的ID和secret寫進下面紅色區(qū)域
\# coding: utf-8
import sys
import json
import urllib2
import base64
import requests
reload(sys)
sys.setdefaultencoding(“utf-8”)
def get_access_token():
url = “https://openapi.baidu.com/oauth/2.0/token”
body = {
“grant_type”:”client_credentials”,
“client_id” :”此處填寫自己的client_id”,
“client_secret”:”此處填寫自己的client_secret”,
}
r = requests.post(url,data=body,verify=True)
respond = json.loads(r.text)
return respond["access_token"]
def yuyinshibie_api(audio_data,token):
speech_data = base64.b64encode(audio_data).decode(“utf-8”)
speech_length = len(audio_data)
post_data = {
“format” : “wav”,
“rate” : 16000,
“channel” : 1,
“cuid” : “B8-27-EB-BA-24-14”,
“token” : token,
“speech” : speech_data,
“l(fā)en” : speech_length
}
url = "http://vop.baidu.com/server_api"
json_data = json.dumps(post_data).encode("utf-8")
json_length = len(json_data)
\#print(json_data)
req = urllib2.Request(url, data=json_data)
req.add_header("Content-Type", "application/json")
req.add_header("Content-Length", json_length)
\#print("asr start request\n")
resp = urllib2.urlopen(req)
\#print("asr finish request\n")
resp = resp.read()
resp_data = json.loads(resp.decode("utf-8"))
if resp_data["err_no"] == 0:
return resp_data["result"]
else:
print(resp_data)
return None
def asr_main(filename,tok):
try:
f = open(filename, “rb”)
audio_data = f.read()
f.close()
resp = yuyinshibie_api(audio_data,tok)
return resp[0]
except Exception,e:
print “e:”,e
return “識別失敗”.encode(“utf-8”)
代碼圖示根據(jù)圖改縮進
識別完成之后呢我們就要開始第三步了我們要和機器人對話那么它一定得回復我們勃刨,對吧。為了能夠智能點,我們就用到了圖靈得接口圖靈真的非常好用能夠查天氣語音****講故事****講笑話下面附上第三步的代碼
3股淡、“圖靈回復"
(1)去圖靈機器人官網(wǎng)注冊創(chuàng)建一個微信機器人
(2)創(chuàng)建圖靈機器人文件輸入代碼
sudo nano Turling.py
(3) 寫入代碼身隐,在紅色處寫自己申請的API KEY
\# coding: utf-8
import requests
import json
import sys
reload(sys)
sys.setdefaultencoding("utf-8")
def Tuling(words):
Tuling_API_KEY = "此處填寫自己的Turling KEY"
body = {"key":Tuling_API_KEY,"info":words.encode("utf-8")}
url = "http://www.tuling123.com/openapi/api"
r = requests.post(url,data=body,verify=True)
if r:
? date = json.loads(r.text)
? print date["text"]
? return date["text"]
else:
? return None
根據(jù)圖片改代碼縮進
4、語音合成
圖靈回復了之后 我們要讓它播放出來 就用到了百度的語音合成
(1)創(chuàng)建語音合成文件
sudo nano yuyinhecheng.py
(2)寫代碼
\# coding: utf-8
import sys
import urllib2
import json
import os
import yuyinshibie
reload(sys)
sys.setdefaultencoding(“utf-8”)
def yuyinhecheng_api(tok,tex):
cuid = “B8-27-EB-BA-24-14”
spd = “4”
url = “http://tsn.baidu.com/text2audio?tex=“+tex+”&lan=zh&cuid=”+cuid+”&ctp=1&tok=”+tok+”&per=3”
\#print url
\#response = requests.get(url)
\#date = response.read()
return url
def tts_main(filename,words,tok):
voice_date = yuyinhecheng_api(tok,words)
f = open(filename,"wb")
f.write(voice_date)
f.close()
根據(jù)圖片改縮進
5唯灵、播放
語音合成之后我們要播放出來用到了mpg123為什么我會用這個呢因為它可以直接播放網(wǎng)頁上的音頻非常的好用
** 安裝mpg123**:
sudo apt-get install mpg123
安裝好了之后 我后面等用到了再說怎么用 現(xiàn)在先不說
現(xiàn)在錄音 語音識別 語音合成 播放 所需要的工具 代碼都準備好了 下面就開始整合在一起
6贾铝、整合
創(chuàng)建最終文件
sudo nano yuyin.py
寫代碼
\# coding: utf-8
import os
import time
import yuyinhecheng
import Turling
import yuyinshibie
tok = yuyinshibie.get_access_token()
switch = True
while switch:
os.system('sudo arecord -D "plughw:1" -f S16_LE -r 16000 -d 3 /home/pi/Desktop/voice.wav')
time.sleep(0.5)
info = yuyinshibie.asr_main("/home/pi/Desktop/voice.wav",tok)
if '關閉'.encode("utf-8") in info:
? while True:
? os.system('sudo arecord -D "plughw:1" -f S16_LE -r 16000 -d 10 /home/pi/Desktop/voice.wav')
? time.sleep(10)
? info = yuyinshibie.asr_main("/home/pi/Desktop/voice.wav",tok)
? if '開啟'.encode("utf-8") in info:
? break
? url = "http://tsn.baidu.com/text2audio?tex=開啟成功&lan=zh&cuid=B8-27-EB-BA-24-14&ctp=1&tok="+tok+"&per=3"
? os.system('mpg123 "%s"'%url)
elif '暫停'.encode("utf-8") in info:
? url = "http://tsn.baidu.com/text2audio?tex=開始暫停&lan=zh&cuid=B8-27-EB-BA-24-14&ctp=1&tok="+tok+"&per=3"
? os.system('mpg123 "%s"'%url)
? time.sleep(10)
? url = "http://tsn.baidu.com/text2audio?tex=暫停結(jié)束&lan=zh&cuid=B8-27-EB-BA-24-14&ctp=1&tok="+tok+"&per=3"
? os.system('mpg123 "%s"'%url)
? continue
else:
? tex = Turling.Tuling(info)
? url = yuyinhecheng.yuyinhecheng_api(tok,tex)
? os.system('mpg123 "%s"'%url)
? time.sleep(0.5)
根據(jù)圖改縮進
7、運行
最后就可以運行機器人了
輸入代碼
sudo python yuyin.py
就可以和機器人對話啦