Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/353.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用麦克风作为源时出现python错误[11001]getaddrinfo_Python - Fatal编程技术网

使用麦克风作为源时出现python错误[11001]getaddrinfo

使用麦克风作为源时出现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.

我修复了程序中的错误,但它被困在“侦听…”

不接受我的命令“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.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秒),然后查看是否得到了什么。不,它不起作用。。。。。