我正在尝试使用创建GUI应用程序Tkinter
。该界面由以下小部件组成:按钮,条目和文本。下图显示了它。
该应用程序背后的想法是:用户在条目上输入一个单词,然后点击“含义”按钮,其含义将显示在文本小部件中。
我的代码分为两类:一类用于GUI,另一类用于应用程序本身。
GUI(删除了之前显示的图像以减少编码):
class Gui:
def __init__(self, master=None):
if master is None:
return
else:
self.word = StringVar()
self.word_meaning = None
self.app_frame = Frame(master)
self.app_frame.grid()
self.create_app_frame()
self.entry_widget = Entry(self.app_frame, textvariable=self.word)
self.button_widget = Button(self.app_frame, text='Meaning', command=self.__handler_entry)
self.text_widget = Text(self.app_frame, height=10, width=30)
self.crete_app_frame()
def crete_app_frame(self):
self.entry_widget.grid(row=0, column=0)
self.button_widget.grid(row=0, column=1)
self.text_widget.grid(row=1, column=0, columnspan=2)
def get_word(self):
return self.word.get()
def set_word_meaning(self, meaning):
self.word_meaning = meaning
def __handler_entry(self):
self.text_widget.delete(0., END)
self.text_widget.insert(END, self.word_meaning)
应用范围:
class InteractiveDictionary:
def __init__(self, filename):
with open(filename, 'r') as file:
self.data = json.load(file)
def get_meaning(self, term):
print('-------------------')
print(f"world is:{term}")
print('-------------------')
term = str(term)
term = term.lower()
if term in self.data:
return self.data[term]
else:
return "The world you\'re looking for doesn\'t exist."
主要:
if __name__ == '__main__':
window = Tk()
window.title('Interactive Dictionary')
dictionary = InteractiveDictionary('words.json')
app = Gui(master=window)
word = app.get_word()
word_meaning = dictionary.get_meaning(word)
if type(word_meaning) == list:
for i in word_meaning:
app.set_word_meaning(i)
else:
app.set_word_meaning(word_meaning)
window.mainloop()
结果显示在控制台上时,应用程序运行正常。但是,当我尝试在GUI上显示时,由get_word()
method捕获的单词未正确传递给字典get_meaning()
method。一个空的传递。
我怀疑这与我在main上调用Tkinter的方式有关。我想让Gui和该应用隔离。因此,删除代码主要__handler_entry()
不是一个选择。有人知道我该如何修复它并使我的应用正常运行?
似乎您不知道GUI的工作原理-都以mainloop()
,开头,显示窗口,从系统获取鼠标/键盘事件,将事件发送到小部件,(重新)绘制小部件。
之前的所有操作都在mainloop()
您看到窗口之前执行-因此word = app.get_word()
在您看到窗口之前已执行。您必须使用在__handler_entry
按下按钮时执行的程序。
更确切地说,在__handler_event`中,您将必须使用所有这些
def __handler_entry(self):
word = self.get_word()
word_meaning = dictionary.get_meaning(word)
if isinstance(word_meaning, list):
for i in word_meaning:
self.set_word_meaning(i)
else:
self.set_word_meaning(word_meaning)
self.text_widget.delete(0., END)
self.text_widget.insert(END, self.word_meaning)
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句