【发布时间】:2023-04-06 14:49:02
【问题描述】:
我使用 ttk.TreeView 作为多列 ListBox,它有效地将我发送给它的 sql 数据显示为表格。当我进行 sql 查询并且树视图显示查询的数据时,可以选择选择数据,因为单击时会突出显示该行。我是否可以单击一行以突出显示数据,然后单击另一个按钮创建一个弹出窗口,其中包含要编辑的数据?
因为我正在使用 SQL,我只需要选择数据,然后我可以使用它从 SQL 表中删除它,而不是从树视图表中删除。这是下面的树,其中包含一些被选中的数据的示例。我可以只传递要编辑或删除的选定数据或类似的东西吗?
编辑:
def OnDoubleClick(self,event):
top1=Toplevel(height=600,width=500)
#frame is just for managing objects not absolutely needed but i think it is good
#to use frame when using object so i have kept it in
curItem = self.tree.focus()
contents =(self.tree.item(curItem))
selectedetails = contents['values']
#this is what you would use to when presenting the selectedd information
self.example_var = StringVar()
self.example_var.set(selectedetails[1])
self.example_txt = Entry(top1,textvariable=self.example_var)
self.example.grid(row=1,column=1)
我将用于管理对象的框架更改为 Toplevel,并更改了入口小部件的位置,使其位于同一位置(top1)。当我双击树中的一个项目时产生的错误消息是:
Exception in Tkinter callback
Traceback (most recent call last):
File "C:\Python33\lib\tkinter\__init__.py", line 1489, in __call__
return self.func(*args)
File "C:\Users\lukeh\Documents\a\test for double click.py", line 278, in OnDoubleClick
self.example.grid(row=1,column=1)
AttributeError: 'MultiColumnListbox' object has no attribute 'example'
当我删除 self.example 开始的代码的后半部分时,代码实际上似乎除了创建 Toplevel 之外没有做任何事情。
编辑:
当我删除 self.example 代码行并仅使用 print (selectedetails) 时,输出正确的数据行。
【问题讨论】:
标签: python sql select tkinter treeview