0

私は、人の話を聞き、その音声を横に繰り返すコードのような基本的なトーキングトムを書いています。スピーカーが話したテキストを表示したいのです。私が直面している問題は、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())
4

2 に答える 2

2
speak("Say something!")
text = listen()
speak("I heard you say " + text)
于 2016-05-30T20:01:14.133 に答える
0

書く:

print(audio)

下:

return recognizer.recognize_google(audio)
于 2016-05-31T17:32:58.280 に答える