我最近开始学习python,最近还学习了Tkinter模块。为了练习,我决定创建一个有点像mySQL工作台的窗口环境。一切都很好,直到我发现提交第二个查询并没有实际删除前一个查询。 我的按钮回调代码如下:
def queryBtnCallBack():
global query
global queryEntry
global resList
global resFrame
j=1
#Delete frame before showing next data
for widget in resFrame.winfo_children():
widget.destroy()
#For this one I also tried
#if resFrame != None:
# resFrame.destroy()
cursor = db.cursor()
resFrame = Tkinter.Frame()
#Check if user has given a correct input
try:
query = queryEntry.get()
cursor.execute(query)
data = cursor.fetchall()
#Let user know if something is wrong
except:
errorQLabel = Tkinter.Label(resFrame, text='Error. Please make sure your query is correct', bg='#99b3e6')
errorQLabel.grid(row=j+1, column=2)
resFrame.configure(background='#99b3e6')
resFrame.pack()
return
for i in data:
resList.append(i)
#Query Results window part
for i in range(len(resList)):
j += 1
resultLabel = Tkinter.Label(resFrame, text=resList[i], bg='#99b3e6')
resultLabel.grid(row=j, column=2)
resFrame.configure(background='#99b3e6')
#Pack the results frame
resFrame.pack()
我现在这样做的方式是删除框架,然后将下一个框架放在现在删除的框架下面。 任何形式的帮助将不胜感激。 提前谢谢
答案 0 :(得分:0)
也许你正试图让它变得比它需要的更复杂。我建议只保留一个大标签并使用新文本重新配置它以显示新数据,可能会在数据中插入换行符以保持各个部分分开。要从条目小部件中删除先前的查询,只需执行queryEntry.delete('0', 'end')
。