javascript
from aip import AipSpeech APP_ID="15420964" #'你的 App ID' API_KEY="6bPrLnkguN5ltxvfxRYP96Hk" #'你的 Api Key' SECRET_KEY="ckSFGccmaGr0b2EPGE3dueb1PkfW5IsW" #'你的 Secret Key' client=AipSpeech(APP_ID,API_KEY,SECRET_KEY) result=client.synthesis("快樂的池塘裏面有隻小青蛙,呱呱呱兒 ","zh",1,{ "vol":5, #音量 "spd":4, #語速 "pit":7, #語調 "per":1 #音色(0,1,3,4) }) print(result) if not isinstance(result,dict): with open("audio.mp3","wb") as f: f.write(result)
from aip import AipSpeech import os """ 你的 APPID AK SK """ APP_ID="15420964" API_KEY="6bPrLnkguN5ltxvfxRYP96Hk" SECRET_KEY="ckSFGccmaGr0b2EPGE3dueb1PkfW5IsW" client=AipSpeech(APP_ID,API_KEY,SECRET_KEY) # 讀取文件 def get_file_content(filePath): with open(filePath, 'rb') as fp: return fp.read() # 識別本地文件 res=client.asr(get_file_content('wb.m4a'), 'pcm', 16000, { 'dev_pid': 1536, }) print(res.get("result")[0])
from aip import AipSpeech import os import time """ 你的 APPID AK SK """ APP_ID="15420964" API_KEY="6bPrLnkguN5ltxvfxRYP96Hk" SECRET_KEY="ckSFGccmaGr0b2EPGE3dueb1PkfW5IsW" client=AipSpeech(APP_ID,API_KEY,SECRET_KEY) ############語音識別########## #讀取文件 def get_file_content(filePath): os.system(f"ffmpeg -y -i {filePath} -acodec pcm_s16le -f s16le -ac 1 -ar 16000 {filePath}.pcm") with open(f"{filePath}.pcm", 'rb') as fp: return fp.read() # 識別本地文件 def audio2text(filename): res=client.asr(get_file_content(filename), 'pcm', 16000, { 'dev_pid': 1536, }) return res.get("result")[0] ############語音合成######### def text2audio(getedtext): filename = f"{time.time()}.mp3" result = client.synthesis(getedtext, "zh", 1, { "vol": 5, "spd": 4, "pit": 7, "per": 0 }) if not isinstance(result, dict): with open(filename, "wb") as f: f.write(result) return filename getedtext=audio2text("wb.m4a") res=text2audio(getedtext) os.system(res)
from aip import AipSpeech import os import time """ 你的 APPID AK SK """ APP_ID="15420964" API_KEY="6bPrLnkguN5ltxvfxRYP96Hk" SECRET_KEY="ckSFGccmaGr0b2EPGE3dueb1PkfW5IsW" client=AipSpeech(APP_ID,API_KEY,SECRET_KEY) ############語音識別########## #讀取文件 def get_file_content(filePath): with open(filePath, 'rb') as fp: return fp.read() # 識別本地文件 def audio2text(filepath): res = client.asr(get_file_content(filepath), 'pcm', 16000, { 'dev_pid': 1536, }) return res.get("result")[0] filename = f"{time.time()}.mp3" ############語音合成######### def text2audio(getedtext): result = client.synthesis(getedtext, "zh", 1, { "vol": 5, "spd": 4, "pit": 7, "per": 1 }) # print(result) if not isinstance(result, dict): with open(filename, "wb") as f: f.write(result) getedtext=audio2text("wb.m4a") text2audio(getedtext) os.system(filename)
from aip import AipSpeech,AipNlp import os import time """ 你的 APPID AK SK """ APP_ID="15420964" API_KEY="6bPrLnkguN5ltxvfxRYP96Hk" SECRET_KEY="ckSFGccmaGr0b2EPGE3dueb1PkfW5IsW" client=AipSpeech(APP_ID,API_KEY,SECRET_KEY) nlp = AipNlp(APP_ID, API_KEY, SECRET_KEY) ############語音識別########## #讀取文件 def get_file_content(filePath): os.system(f"ffmpeg -y -i {filePath} -acodec pcm_s16le -f s16le -ac 1 -ar 16000 {filePath}.pcm") with open(f"{filePath}.pcm", 'rb') as fp: return fp.read() # 識別本地文件 def audio2text(filename): res=client.asr(get_file_content(filename), 'pcm', 16000, { 'dev_pid': 1536, }) return res.get("result")[0] ############語音合成######### def text2audio(getedtext): filename = f"{time.time()}.mp3" result = client.synthesis(getedtext, "zh", 1, { "vol": 5, "spd": 4, "pit": 7, "per": 0 }) if not isinstance(result, dict): with open(filename, "wb") as f: f.write(result) return filename ##########圖靈################ def to_tuling(text): import requests args = { "reqType": 0, "perception": { "inputText": { "text": text } }, "userInfo": { "apiKey": "e963f65c4c7a466a80e5aaa3510da2fa", "userId": "1111" } } url = "http://openapi.tuling123.com/openapi/api/v2" res = requests.post(url, json=args) print(res) text = res.json().get("results")[0].get("values").get("text") print("圖靈答案",text) return text ###########調用################ getedtext=audio2text("wb.m4a") if nlp.simnet("你叫什麼名字",getedtext).get("score")>=0.68: getedtext="我纔不告訴你呢,你個糟老頭子壞得很" else: getedtext=to_tuling(getedtext) res=text2audio(getedtext) os.system(res)
應用結構:css
在index.html中 html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <audio controls autoplay id="player"></audio> <p> <button onclick="start_reco()" style="background-color: yellow">錄製語音指令</button> </p> <p> <button onclick="stop_reco_audio()" style="background-color: blue">發送語音指令</button> </p> </body> <!--<script type="application/javascript" src="/static/Recorder.js"></script>--> <script type="application/javascript" src="https://cdn.bootcss.com/recorderjs/0.1.0/recorder.js"></script> <script type="text/javascript" src="/static/jQuery3.1.1.js"></script> <script type="text/javascript"> var reco = null; var audio_context = new AudioContext(); navigator.getUserMedia = (navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia); navigator.getUserMedia({audio: true}, create_stream, function (err) { console.log(err) }); function create_stream(user_media) { var stream_input = audio_context.createMediaStreamSource(user_media); reco = new Recorder(stream_input); } function start_reco() { reco.record(); } function stop_reco_audio() { reco.stop(); send_audio(); reco.clear(); } function send_audio() { reco.exportWAV(function (wav_file) { var formdata = new FormData(); formdata.append("record", wav_file); console.log(formdata); $.ajax({ url: "http://192.168.43.158:9527/ai", type: 'post', processData: false, contentType: false, data: formdata, dataType: 'json', success: function (data) { document.getElementById("player").src ="http://192.168.43.158:9527/get_audio/" + data.filename } }); }) } </script> </html>
在app.py中前端
from flask import Flask,render_template,request,jsonify,send_file from uuid import uuid4 import baidu_ai app = Flask(__name__) @app.route("/") def index(): return render_template("index.html") @app.route("/ai",methods=["POST"]) def ai(): # 1.保存錄音文件 print(111) audio = request.files.get("record") print('audio',audio) filename = f"{uuid4()}.wav" audio.save(filename) #2.將錄音文件轉換爲PCM發送給百度進行語音識別 q_text = baidu_ai.audio2text(filename) print(8585) print(q_text) #3.將識別的問題交給圖靈或自主處理獲取答案 a_text = baidu_ai.to_tuling(q_text) print(a_text) #4.將答案發送給百度語音合成,合成音頻文件 a_file = baidu_ai.text2audio(a_text) print(a_file) #5.將音頻文件發送給前端播放 return jsonify({"filename":a_file}) @app.route("/get_audio/<filename>") def get_audio(filename): print(filename) return send_file(filename) if __name__ == '__main__': app.run("0.0.0.0",9527,debug=True)
在baidu_ai.py中java
from aip import AipSpeech,AipNlp import time,os """ 你的 APPID AK SK """ APP_ID="15420964" API_KEY="6bPrLnkguN5ltxvfxRYP96Hk" SECRET_KEY="ckSFGccmaGr0b2EPGE3dueb1PkfW5IsW" # client = AipSpeech(APP_ID, API_KEY, SECRET_KEY) nlp = AipNlp(APP_ID, API_KEY, SECRET_KEY) client = AipSpeech(APP_ID, API_KEY, SECRET_KEY) # 讀取文件 def get_file_content(filePath): print(234) os.system(f"ffmpeg -y -i {filePath} -acodec pcm_s16le -f s16le -ac 1 -ar 16000 {filePath}.pcm") print(354) with open(f"{filePath}.pcm", 'rb') as fp: return fp.read() def audio2text(filepath): # 識別本地文件 print(123) res = client.asr(get_file_content(filepath), 'pcm', 16000, { 'dev_pid': 1536, }) print(456456) print('----------res',res) return res.get("result")[0] def text2audio(text): filename = f"{time.time()}.mp3" result = client.synthesis(text, 'zh', 1, { 'vol': 5, "spd": 3, "pit": 7, "per": 4 }) # 識別正確返回語音二進制 錯誤則返回dict 參照下面錯誤碼 if not isinstance(result, dict): with open(filename, 'wb') as f: f.write(result) return filename def to_tuling(text): import requests args = { "reqType": 0, "perception": { "inputText": { "text": text } }, "userInfo": { "apiKey": "e963f65c4c7a466a80e5aaa3510da2fa", "userId": "1111" } } url = "http://openapi.tuling123.com/openapi/api/v2" res = requests.post(url, json=args) print(res) text = res.json().get("results")[0].get("values").get("text") print("圖靈答案",text) return text