如何修复麦克风无法正确拾取输入的异常错误?

2024-05-29 00:03:07 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在以siri和google assistant的形式构建一个薄弱的人工智能平台,每次我运行我的代码时,它总是返回“对不起,我没有捕捉到那个”——这是一个异常,而不是通过我的麦克风接收输入。我正在跟随YouTube教程来构建这个,因为我对python相当陌生,因此我不知道问题出在哪里,因为它似乎对教程中的人很好。有人能走吗帮我修好这个?谢谢

import pyttsx3
import speech_recognition as sr
import datetime
import wikipedia
import webbrowser
import os
import smtplib
import pythoncom

print("Initializing Karren")

MASTER = "Nadeem"

engine = pyttsx3.init('sapi5')
voices = engine.getProperty('voices')
engine.setProperty('voice', voices[1].id)

def speak(text):
    engine.say(text)
    engine.runAndWait()


def wishMe():
    hour = int(datetime.datetime.now().hour)

    if hour>=0 and hour <12:
        speak("Good Morning" + MASTER)

    elif hour>=12 and hour<18:
        speak("Good Afternoon" + MASTER)
    else:
        speak("Good Evening" + MASTER)


    speak("How may I assist you?")

def takeCommand():
    r = sr.Recognizer()
    with sr.Microphone() as source:
        print("Listening...")
        audio = r.listen(source)
    try :
        print("Recognizing...")
        query = r.recognize_google(audio, language ='en-uk')
            print(f"user said: {query}\n")

        except Exception as e:
            print("Sorry i didn't catch that...")

speak("Initializing Karren...")
wishMe()
query = takeCommand()

#Logic
if query:
    if 'wikipedia' in query.lower():
        speak('Searching wikipedia...')
        query = query.replace("wikipedia", "")
        results = wikipedia.summary(query, sentences =2)
        print(results)
        speak(results)


    if 'open youtube' in query.lower():
        webbrowser.open("youtube.com")

Tags: importmasterdatetimeifdefaswikipediaquery
1条回答
网友
1楼 · 发布于 2024-05-29 00:03:07

这是更新后的代码@iSavageSkull

import pyttsx3
import speech_recognition as sr
import datetime
import wikipedia
import webbrowser
import os
import smtplib
import pythoncom

print("Initializing Karren")

MASTER = "Nadeem"

engine = pyttsx3.init('sapi5')
voices = engine.getProperty('voices')
engine.setProperty('voice', voices[1].id)

def speak(text):
    engine.say(text)
    engine.runAndWait()


def wishMe():
    hour = int(datetime.datetime.now().hour)

    if hour>=0 and hour <12:
        speak("Good Morning" + MASTER)

    elif hour>=12 and hour<18:
        speak("Good Afternoon" + MASTER)
    else:
        speak("Good Evening" + MASTER)


    speak("How may I assist you?")

def takeCommand():
    r = sr.Recognizer()
    with sr.Microphone() as source:
        print("Listening...")
        audio = r.listen(source)
    try :
        print("Recognizing...")
        query = r.recognize_google(audio, language ='en-uk')
        print(f"user said: {query}\n")

    except Exception as e:
        print("Sorry i didn't catch that...")

speak("Initializing Karren...")
wishMe()
query = takeCommand()

#Logic
if query:
    if 'wikipedia' in query.lower():
        speak('Searching wikipedia...')
        query = query.replace("wikipedia", "")
        results = wikipedia.summary(query, sentences =2)
        print(results)
        speak(results)


    if 'open youtube' in query.lower():
        webbrowser.open("youtube.com")

您在此处执行的错误:

  1. def takeCommand()下,print(f"user said: {query}\n")缩进错误,应该正确缩进

  2. 在相同的def takeCommand()

    except Exception as e:
        print("Sorry i didn't catch that...")

这里再次强调,它是一个缩进错误,这就是为什么它总是保持打印错误,即使代码产生了合法的输出

运行你的更新代码,程序运行良好

相关问题 更多 >

    热门问题