[英]tkinter for loop entry bind connected to sqlite3
我很难通过在 for 循环中创建的条目的绑定返回正确的 sqlite3 行
我知道,我不知道如何用文字来解释,所以这是一段代码
if x == '':
counter_kit_label = 10
for kit in find_everything_from_db('*', 'kit'):
kit_label = tk.Label(self.kit_listbox, text=f"{kit[0]}, {kit[1].capitalize()}, {kit[2].capitalize()},",
bg='white')
kit_label.place(x=5, y=counter_kit_label)
kit_label.bind('<Enter>', lambda event: evidenzia(event))
kit_label.bind('<Leave>', lambda event: non_evidenzia(event))
kit_label.bind('<Button-1>', lambda: None) # todo: creare event bind
kit_entry_var = tk.StringVar()
kit_entry = tk.Entry(self.kit_listbox, textvariable=kit_entry_var)
kit_entry_var.set(f"{kit[4].capitalize()}")
kit_entry.place(x=108, y=counter_kit_label)
kit_entry.bind('<Return>', lambda event: self.modifica_luogo_kit(kit_entry.get(), kit, event))
counter_kit_label += 30
else:
pass
def modifica_luogo_kit(self,luogo, kit, event=None):
print(event.widget.get())
print(kit)
当我运行脚本并在第一个 tk.Entry 上按“返回键”时,“print(event.widget.get())”的打印结果对应于 sqlite3 选项卡第一行预设的第一个条目,但是“ print(kit)" 对应sqlite3 tab的最新一行
尝试这个:
import tkinter as tk
from functools import partial
def modifica_luogo_kit(luogo, kit, event=None):
print("Data in widget =", luogo.get())
print("Entry number:", kit)
root = tk.Tk()
for kit in range(10):
kit_entry = tk.Entry(root)
kit_entry.pack()
command = partial(modifica_luogo_kit, kit_entry, kit)
kit_entry.bind("<Return>", command)
我删除了所有不必要的细节,以便更容易解决问题。 我使用functools.partial
创建了一个在按下“ <Return>
”时执行的命令。 有关functools.partial
的更多信息,请查看此。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.