使用Tkinter和语音转文本

时间:2019-07-02 05:34:39

标签: python tkinter speech-recognition speech-to-text

我必须用2个代码中的1个进行线程化;一个是语音到文本的转换,另一个是 Tkinter GUI ,它们都是相互关联的,如果有人说了话就必须在GUI中进行一些更改。 问题是,当我在主循环中创建线程GUI和语音时,它可以正常工作,直到我执行以下条件:如果有人说“ HOME”,则必须在GUI中显示新按钮。它给出了一个错误,即主线程不在主循环中 当我尝试将语音代码保留在线程中并将GUI保留在mainloop中时;提示“ 信号应该在主循环中” 如果我都保留在主循环中并且不执行线程处理,那么如果先编写GUI,则显示GUI并卡在其中,如果先编写语音,它将继续运行语音代码(因为它是无穷FOR循环)

#*********************************** IMPORTING MODULES*****************
import tkinter
from tkinter import*
import tkinter.messagebox
import sqlite3
import os
from multiprocessing import Process
from pocketsphinx import LiveSpeech, get_model_path
import threading
from time import sleep

model_path = get_model_path()
window = tkinter.Tk()
window.title("Smart Notice Board")

top = Canvas(window,width=400,height=200)
top.pack(fill=X)

#*************** TKINTER GUI CODE******************
def gui():

 button_5 = Button(text='PORTAL SYSTEM', height = 2, width=17, activebackground = '#33B5e5', bg = 'brown', fg = 'white',command  = portal )
 top.create_window(80,80, anchor='nw', window = button_5)
 window.mainloop()
def portal():
   print("2")



#****************  speech TO text CODE***************

def speech(): 
    speech = LiveSpeech(
        verbose=False,
        sampling_rate=16000,
        buffer_size=2048,
        no_search=False,
        full_utt=False,
        hmm=os.path.join(model_path, 'en-us'),
        lm=os.path.join(model_path, '8582.lm'),
        dic=os.path.join(model_path, '8582.dict')
    )

    for phrase in speech:
        print(phrase)
        a=str(phrase)
        print(a)

#************************** MAIN LOOP************************

if __name__ == "__main__":

    #************ FOR THREADING************


    thread1 = threading.Thread(target=gui)
    #thread2 = threading.Thread(target=speech)
    #thread1.daemon = True
    thread1.start()
    #thread2.start()


    #thread1.join()
    #thread2.join()


    #************ FOR MULTIPROCESSING****************

    #processes=[]
    #P1 = Process(target=gui)
    #P2 = Process(target=speech)
    #processes.append(P1)
    #processes.append(P2)
    #P2.daemon = True
    # Will execute both in parallel
    #P1.start()
    #P2.start()
    # Joins threads back to the parent process, which is this
    # program
    #P1.join()
    #P2.join()


    #****************** live speech code*************
    #gui()
    #speech()
    speech = LiveSpeech(
        verbose=False,
        sampling_rate=16000,
        buffer_size=2048,
        no_search=False,
        full_utt=False,
        hmm=os.path.join(model_path, 'en-us'),
        lm=os.path.join(model_path, '8582.lm'),
        dic=os.path.join(model_path, '8582.dict')
    )

    for phrase in speech:
        print(phrase)
        a=str(phrase)
        print(a)

        button_6= Button(text='HOME SYSTEM', height = 2, width=17, activebackground = '#33B5e5', bg = 'brown', fg = 'white',command  = portal )
        top.create_window(20,20, anchor='nw', window = button_6)

在cond之前,代码可以正常工作,直到我输入为止

Code works fine until i put if cond

显示此错误,

show this error

0 个答案:

没有答案