我应该可以使用循环来执行下面的操作,而不是写出比我需要的更多的小部件,并缩短我的代码。这就是我现在这样做的方式:
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个具有不同名称的复选框和输入框,以便我可以从我的数据库中插入记录。
答案 0 :(得分:4)
创建一个包含所有检查按钮的列表,而不是将15个变量命名为c1
,c2
... 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]
。