私は、人の話を聞き、その音声を横に繰り返すコードのような基本的なトーキングトムを書いています。スピーカーが話したテキストを表示したいのです。私が直面している問題は、print コマンドと listen コマンドを同時に使用できないことです。このフレーズを 2 回話す必要があります。1 回目は画面に印刷するため、もう 1 回はそれを繰り返すためです。これらの両方が同時に発生することを理解したいと思います。つまり、フレーズを 2 回繰り返さなくても、オーディオを同時に繰り返して表示する必要があります。
import speech_recognition
import pyttsx
speech_engine = pyttsx.init()
speech_engine.setProperty('rate', 150)
def speak(text):
speech_engine.say(text)
speech_engine.runAndWait()
recognizer = speech_recognition.Recognizer()
def listen():
with speech_recognition.Microphone() as source:
recognizer.adjust_for_ambient_noise(source)
audio = recognizer.listen(source)
try:
return recognizer.recognize_google(audio)
except speech_recognition.UnknownValueError:
print("Could not understand audio")
except speech_recognition.RequestError as e:
print("Recog Error; {0}".format(e))
return ""
speak("Say something!")
print (listen())
speak("I heard you say " + listen())