如何从 python 中的一个短语中识别和执行多个命令?
How to recognize and execute multiple commands from a phrase in python?
我创建了一个程序,它使用 google 语音识别来收听我们的声音,然后执行为该短语编写的程序。
这是部分代码:
import speech_recognition as sr
import os
def takeCommand():
#It takes microphone input from the user and returns string output
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("User said: ",query)
except Exception as e:
# print(e)
print("Say that again please...")
os.startfile('JARVIS.py')
os._exit()
return "None"
return query
if __name__ == "__main__":
while True:
query = takeCommand().lower()
command_history()
# Logic for executing tasks based on query
if 'chrome' in query:
os.startfile("C:/............./chrome.exe")
elif 'photoshop' in query:
os.startfile("C:/............../photoshop.exe")
它工作正常,但如果我想从语音中识别多个命令怎么办?
例如,如果我说,“打开 chrome 和 photoshop”,那么它只会打开 chrome,因为它列在前面,然后是程序会停。
但是我想从语音中提取每一个命令,那么,怎么办呢?
任何帮助都会被认为是很好的,抱歉我的英语不好
您的程序在 chrome 处结束,因为您正在使用 if-elif。试试 if...if
你实际上不能只用一堆 if-elif-else
语句来制作这样的 AI。对于您想要完成的任务,您应该选择自然语言处理之类的东西。 Python 像 spacy
这样的模块你能帮忙吗?首先,你应该提取用户所说的内容(你做得很好),然后将其提供给自然语言处理算法,该算法可以为你提供语音的 intent 然后你应该继续执行。
我创建了一个程序,它使用 google 语音识别来收听我们的声音,然后执行为该短语编写的程序。 这是部分代码:
import speech_recognition as sr
import os
def takeCommand():
#It takes microphone input from the user and returns string output
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("User said: ",query)
except Exception as e:
# print(e)
print("Say that again please...")
os.startfile('JARVIS.py')
os._exit()
return "None"
return query
if __name__ == "__main__":
while True:
query = takeCommand().lower()
command_history()
# Logic for executing tasks based on query
if 'chrome' in query:
os.startfile("C:/............./chrome.exe")
elif 'photoshop' in query:
os.startfile("C:/............../photoshop.exe")
它工作正常,但如果我想从语音中识别多个命令怎么办? 例如,如果我说,“打开 chrome 和 photoshop”,那么它只会打开 chrome,因为它列在前面,然后是程序会停。 但是我想从语音中提取每一个命令,那么,怎么办呢?
任何帮助都会被认为是很好的,抱歉我的英语不好
您的程序在 chrome 处结束,因为您正在使用 if-elif。试试 if...if
你实际上不能只用一堆 if-elif-else
语句来制作这样的 AI。对于您想要完成的任务,您应该选择自然语言处理之类的东西。 Python 像 spacy
这样的模块你能帮忙吗?首先,你应该提取用户所说的内容(你做得很好),然后将其提供给自然语言处理算法,该算法可以为你提供语音的 intent 然后你应该继续执行。