如下所示:
from win32com.client import constantsimport osimport win32com.clientimport pythoncom speaker = win32com.client.Dispatch("SAPI.SPVOICE") class SpeechRecognition: def __init__(self, wordsToAdd): self.speaker = win32com.client.Dispatch("SAPI.SpVoice") self.listener = win32com.client.Dispatch("SAPI.SpSharedRecognizer") self.context = self.listener.CreateRecoContext() self.grammar = self.context.CreateGrammar() self.grammar.DictationSetState(0) self.wordsRule = self.grammar.Rules.Add("wordsRule", constants.SRATopLevel + constants.SRADynamic, 0) self.wordsRule.Clear() [self.wordsRule.InitialState.AddWordTransition(None, word) for word in wordsToAdd] self.grammar.Rules.Commit() self.grammar.CmdSetRuleState("wordsRule", 1) self.grammar.Rules.Commit() self.eventHandler = ContextEvents(self.context) self.say("Started successfully") def say(self, phrase): self.speaker.Speak(phrase)class ContextEvents(win32com.client.getevents("SAPI.SpSharedRecoContext")): def OnRecognition(self, StreamNumber, StreamPosition, RecognitionType, Result): newResult = win32com.client.Dispatch(Result) print("小伙子你在說 ", newResult.PhraseInfo.GetText()) speechstr=newResult.PhraseInfo.GetText() if speechstr=="張三": speaker.Speak("zhaodahai love fengjie") elif speechstr=="你好": speaker.Speak("hello world") elif speechstr=="國慶快樂": speaker.Speak("Happy nationalday") elif speechstr=="新年快樂": speaker.Speak("happy New Year") elif speechstr=="李四": speaker.Speak("a beauty baby") elif speechstr=="王五": speaker.Speak("a little boy") elif speechstr=="趙六": speaker.Speak("a boy can coding") else: pass if __name__ == '__main__': speaker.Speak("語音識別開啟") wordsToAdd = ["張三", "你好", "國慶快樂", "新年快樂", "李四", "王五", "趙六",] speechReco = SpeechRecognition(wordsToAdd) while True: pythoncom.PumpWaitingMessages() 以上這篇對Python 語音識別框架詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答