如何在循环中创建具有不同名称的多个tkinter小部件?

时间:2014-11-21 17:34:18

标签: python sqlite tkinter

我应该可以使用循环来执行下面的操作,而不是写出比我需要的更多的小部件,并缩短我的代码。这就是我现在这样做的方式:

db = sqlite3.connect('/path/to/database')
cursor = db.cursor()
cursor.execute("SELECT Drug FROM database where current >= 1")
allrec = cursor.fetchall()
numrec = len(allrec)
cursor.execute("SELECT Drug FROM database where current >= 1")
results = cursor.fetchone()
if numrec == 0:
    exit
else:
    c1=Checkbutton(frame1,variable=var1)
    c1.grid(row=0,column=0,sticky='nw')
    c1.config(bg='black')
    e1=Entry(frame1, bg="black", fg="white")
    e1.grid(row=0, column=1, sticky=NW)
    e1.delete(0, END)
    for row in results:
        e1.insert(END, *results)
results = cursor.fetchone()
if numrec <= 1:
    quit
else:
    c2=Checkbutton(frame1,variable=var2)
    c2.grid(row=1,column=0,sticky='nw')
    c2.config(bg='black')
    e2=Entry(frame1, bg="black", fg="white")
    e2.grid(row=1, column=1, sticky=NW)
    e2.delete(0, END)
    for row in results:
        e2.insert(END, *results)

    record 3 ........
    record 4 ........
    .......
    .......
    record 15 .......

这将创建15个具有不同名称的复选框和输入框,以便我可以从我的数据库中插入记录。

1 个答案:

答案 0 :(得分:4)

创建一个包含所有检查按钮的列表,而不是将15个变量命名为c1c2 ... c15。对你的参赛作品和vars做同样的事。

checkbuttons = []
entries = []
vars = []
for i in range(numrec):
    results = cursor.fetchone()
    var = IntVar()
    check_button=Checkbutton(frame1,variable=var)
    check_button.grid(row=i,column=0,sticky='nw')
    check_button.config(bg='black')
    entry=Entry(frame1, bg="black", fg="white")
    entry.grid(row=i, column=1, sticky=NW)
    entry.delete(0, END)
    for row in results:
        entry.insert(END, *results)
    checkbuttons.append(check_button)
    entries.append(entry)
    vars.append(var)

现在而不是例如使用e6的第六个条目,您可以使用entries[5]