我是Python新手。我本来应该用多个菜单创建一个GUI。单击特定菜单时,应启动新进程,并且不应挂起用户界面。但我无法做到这一点。在网络搜索后,我做了类似的代码。
在此代码中,我的目标是使“打印深度”语句处于活动状态而不会挂起UI(单击(单击我)后会激活)
请帮助我。
import Tkinter
class simpleapp_tk(Tkinter.Tk):
def __init__(self,parent):
Tkinter.Tk.__init__(self,parent)
self.parent = parent
self.initialize()
def initialize(self):
self.grid()
self.entryVariable = Tkinter.StringVar()
self.entry = Tkinter.Entry(self,textvariable=self.entryVariable)
self.entry.grid(column=0,row=0,sticky='EW')
self.entry.bind("<Return>", self.OnPressEnter)
self.entryVariable.set(u"Enter text here.")
button = Tkinter.Button(self,text=u"Click me !",
command=self.OnButtonClick)
button.grid(column=1,row=0)
self.labelVariable = Tkinter.StringVar()
label = Tkinter.Label(self,textvariable=self.labelVariable,
anchor="w",fg="white",bg="blue")
label.grid(column=0,row=1,columnspan=2,sticky='EW')
self.labelVariable.set(u"Hello !")
self.grid_columnconfigure(0,weight=1)
self.resizable(True,False)
self.update()
self.geometry(self.geometry())
self.entry.focus_set()
self.entry.selection_range(0, Tkinter.END)
def OnButtonClick(self):
while True:
print 'deep'
def OnPressEnter(self,event):
self.labelVariable.set( self.entryVariable.get()+" (You pressed ENTER)" )
self.entry.focus_set()
self.entry.selection_range(0, Tkinter.END)
if __name__ == "__main__":
app = simpleapp_tk(None)
app.title('my application')
app.mainloop()
答案 0 :(得分:1)
import threading
class simpleapp_tk(Tkinter.Tk):
# .............................
def OnButtonClick(self):
thr = threading.Thread(target=self.print_deep)
thr.start()
def print_deep(self):
while True:
print 'deep'
如果要创建新进程,则需要创建将在单独进程中运行的单独脚本。 我仍然认为更好的解决方案是使用线程。
proc.py
while True:
print('deep')
parent_proc.py
import subprocess
import sys
class simpleapp_tk(Tkinter.Tk):
# .............................
def OnButtonClick(self):
subprocess.Popen(args=['python', 'proc.py'], stdout=sys.stdout])
答案 1 :(得分:0)
您不需要多个线程来启动外部进程。 Popen()
不等待子进程结束。它会立即返回。这是一个complete code example that starts/stops a tkinter progressbar on the start/end of a subprocess without using threads
。
不相关:在不阻止GUI的情况下运行while True: print 'deep'; time.sleep(1)
(假设print('deep')
不会长时间阻止),您可以使用parent.after()
方法:
def OnButtonClick(self):
self._step()
def _step(self):
print('deep')
self.parent.after(1000, self._step) # call _step in a second