|
-
- """
- google voice service
- """
-
- import pathlib
- import subprocess
- import time
- import speech_recognition
- import pyttsx3
- from common.log import logger
- from common.tmp_dir import TmpDir
- from voice.voice import Voice
-
-
- class GoogleVoice(Voice):
- recognizer = speech_recognition.Recognizer()
- engine = pyttsx3.init()
-
- def __init__(self):
- # 语速
- self.engine.setProperty('rate', 125)
- # 音量
- self.engine.setProperty('volume', 1.0)
- # 0为男声,1为女声
- voices = self.engine.getProperty('voices')
- self.engine.setProperty('voice', voices[1].id)
-
- def voiceToText(self, voice_file):
- new_file = voice_file.replace('.mp3', '.wav')
- subprocess.call('ffmpeg -i ' + voice_file +
- ' -acodec pcm_s16le -ac 1 -ar 16000 ' + new_file, shell=True)
- with speech_recognition.AudioFile(new_file) as source:
- audio = self.recognizer.record(source)
- reply = {}
- try:
- text = self.recognizer.recognize_google(audio, language='zh-CN')
- logger.info(
- '[Google] voiceToText text={} voice file name={}'.format(text, voice_file))
- reply = {"type": "TEXT", "content": text}
- except speech_recognition.UnknownValueError:
- reply = {"type": "ERROR", "content": "抱歉,我听不懂"}
- except speech_recognition.RequestError as e:
- reply = {"type": "ERROR", "content": "抱歉,无法连接到 Google 语音识别服务;{0}".format(e)}
- finally:
- return reply
- def textToVoice(self, text):
- try:
- textFile = TmpDir().path() + '语音回复_' + str(int(time.time())) + '.mp3'
- self.engine.save_to_file(text, textFile)
- self.engine.runAndWait()
- logger.info(
- '[Google] textToVoice text={} voice file name={}'.format(text, textFile))
- reply = {"type": "VOICE", "content": textFile}
- except Exception as e:
- reply = {"type": "ERROR", "content": str(e)}
- finally:
- return reply
|