使用麦克风作为源时出现python错误[11001]getaddrinfo
我修复了程序中的错误,但它被困在“侦听…” 不接受我的命令“sapi5”有问题吗 我应该试试其他tts引擎吗 这是我的密码:使用麦克风作为源时出现python错误[11001]getaddrinfo,python,Python,我修复了程序中的错误,但它被困在“侦听…” 不接受我的命令“sapi5”有问题吗 我应该试试其他tts引擎吗 这是我的密码: import pyttsx3 import dateTime import speech_recognition as sr import webbrowser import wikipedia import os engine = pyttsx3.init('sapi5') voices = engine.getProperty('voices') engine.
import pyttsx3
import dateTime
import speech_recognition as sr
import webbrowser
import wikipedia
import os
engine = pyttsx3.init('sapi5')
voices = engine.getProperty('voices')
engine.setProperty('voice',voices[0].id)
def speak(audio):
engine.say(audio)
# print(audio)
engine.runAndWait()
def wishMe():
hour = int(datetime.datetime.now().hour)
if hour >= 0 and hour < 12:
print("Good Morning!, sir")
speak("Good Morning!, sir")
elif hour >= 12 and hour < 18:
print("Good Afternoon!, sir")
speak("Good Afternoon!, sir")
else:
print("Good Evening!, sir")
speak("Good Evening!, sir")
print("I am Mark. your virtual assistant, please tell me how can I help you? ")
speak("I am Mark. your virtual assistant, please tell me how can I help you? ")
def takeCommand():
r = sr.Recognizer()
with sr.Microphone() as source:
print("am Listining...")
r.pause_threshold = 1
audio = r.listen(source)
try:
print("Recognizing...")
query = r.recognize_google(audio, language='en-in')
print(f"user said: {query}\n")
except Exception as e:
print(e)
print("say that again please..")
return "None"
return query
if __name__ == "__main__":
wishMe()
while True:
query = takeCommand().lower()
elif 'bye' in query:
print("good bye, see you soon")
speak("good bye, see you soon")
exit()
导入pyttsx3
导入日期时间
将语音识别作为sr导入
导入网络浏览器
导入维基百科
导入操作系统
engine=pyttsx3.init('sapi5')
voices=engine.getProperty('voices')
engine.setProperty('voice',voices[0].id)
def语音(音频):
引擎。比如说(音频)
#打印(音频)
engine.runAndWait()
def wishMe():
hour=int(datetime.datetime.now().hour)
如果小时>=0且小时<12:
打印(“早上好,先生”)
说(“早上好,先生”)
elif小时数>=12且小时数<18:
打印(“下午好,先生”)
发言(“下午好,先生”)
其他:
打印(“晚上好,先生”)
说(“晚上好,先生”)
打印(“我是马克。你的虚拟助理,请告诉我有什么可以帮你的吗?”)
说话(“我是马克。你的虚拟助手,请告诉我我能为你做些什么?”)
def takeCommand():
r=高级识别器()
使用sr.麦克风()作为源:
打印(“am列表…”)
r、 暂停\u阈值=1
音频=r.listen(源)
尝试:
打印(“识别…”)
query=r.recognize\u谷歌(音频、语言)
打印(f“用户说:{query}\n”)
例外情况除外,如e:
打印(e)
打印(“请再说一遍……”)
返回“无”
返回查询
如果名称=“\uuuuu main\uuuuuuuu”:
wishMe()
尽管如此:
query=takeCommand().lower()
在查询中选择“再见”:
打印(“再见,再见”)
说(“再见,再见”)
退出()
它不需要我的任何命令
如何修复它?随便看一眼
listen
方法的文档,我就知道它可能被卡住了。尝试将timeout
传递给r.listen
(例如r.listen(source,timeout=10)
以最多监听10秒),然后查看是否得到了什么。不,它不起作用。。。。。