Как запустить эту программу в Raspberry Pi - PullRequest
0 голосов
/ 03 марта 2020

Я сделал эту python программу для Windows. Пожалуйста, помогите мне баллотироваться на Raspberry Pi. Это программа для голосового чата, которая распознает команды и отвечает на задание в соответствии с ним. Он хорошо работает на windows python IDE, но, к сожалению, не отвечает на Raspberry Pi. Пожалуйста, помогите мне решить эту проблему и скажите, как запустить эту программу в Raspberry 4

Ошибка в этой строке:

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

Программа:

import pyttsx3 #pip install pyttsx3
import speech_recognition as sr #pip install speechRecognition
import datetime
import wikipedia #pip install wikipedia
import webbrowser
import os
import smtplib
import time
import pyfirmata
from pygame import mixer

try:

    board = pyfirmata.Arduino('COM5')
    led = board.get_pin('d:6:o')
except:
    print("Arduino is not connected")
x=0

def songPlayer(x):
    i =x

    music_dir = 'E:\\Songs'
    songs = os.listdir(music_dir)
    mixer.init()
    mixer.music.load(os.path.join(music_dir, songs[i]))
    mixer.music.play()


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


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


def wishMe():
    hour = int(datetime.datetime.now().hour)
    if hour>=0 and hour<12:
        speak("Good Morning!")

    elif hour>=12 and hour<18:
        speak("Good Afternoon!")   

    else:
        speak("Good Evening!")  

    speak("I am cham Sir. Please tell me how may I help you")       

def takeCommand():
    r = sr.Recognizer()
    with sr.Microphone() as source:
        print("Listening...")
        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:
    # if 1:
        query = takeCommand().lower()

        if 'wikipedia' in query:
            speak('Searching Wikipedia...')
            try:

                query = query.replace("wikipedia", "")
                results = wikipedia.summary(query, sentences=2)
                speak("According to Wikipedia")
                print(results)
                speak(results)

            except:
                speak("sorry I unable to find it")

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

        elif 'open google' in query:
            webbrowser.open("google.com") 


        elif 'What is your name' in query:
            speak("I am cham sir")


        elif 'who created you' in query:
            speak("mr. logesh mohan created me")

        elif 'play music' in query:
            speak("playing Music")
            songPlayer(x)


        elif 'next song' in query:
            x+=1
            songPlayer(x)


        elif 'previous song' in query:
            x-=1
            songPlayer(x)


        elif 'stop music' in query:
            mixer.music.stop()


        elif 'the time' in query:
            strTime = datetime.datetime.now().strftime("%H:%M:%S")    
            speak(f"Sir, the time is {strTime}")

        elif 'light on' in query:
             led.write(1)

        elif 'light off' in query:
             led.write(0)

        elif 'make a call' in query:
            print(calling)





        elif 'go and sleep' in query:
            exit()

Это программа для AI Assistant

1 Ответ

0 голосов
/ 06 марта 2020

Инициализация кода Pyttsx3 изменяется с windows на Linux, поскольку голосовой идентификатор будет отличаться.

Попробуйте настроить этот фрагмент, это прекрасно работает с Linux Ubuntu:

import pyttsx3

engine = pyttsx3.init()

engine.setProperty('rate', 150)
engine.setProperty('volume', 0.5)
voices = engine.getProperty('voices')
for voice in voices:
    engine.setProperty('voice', voice.id)
    # engine.say('The quick brown fox jumped over the lazy dog.')
    engine.say("Hello, I am robot")
engine.runAndWait()

Вы можете выбрать голосовой идентификатор из доступного списка и использовать ID-константу для инициализации движка.

Поскольку вы не упомянули журнал ошибок, это также может быть вызвано тем, что у вас не установлен espeak в вашей системе

вы можете попробовать это, чтобы исправить ошибку espeak:

sudo apt-get update && apt-get upgrade -y && apt-get install espeak

Если проблема не устранена, добавьте журнал ошибок, чтобы мы могли помочь вам в дальнейшем.

...