Tkinter - 动态删除网格中的行

时间:2018-02-08 19:54:32

标签: python python-3.x tkinter python-3.5

我有一些代码读取.csv文件然后使用网格显示内容并迭代行/列来打包它们,如下所示:

from tkinter import *
import csv

def createStandardTable(f,window):
    global trow
    global table
    global w
    global sizes
    global record
    global column
    handle = csv.reader(f)
    length = len(next(handle))

    sizes = [0] * length
    for record in handle:

        for p,column in enumerate(record):
            if len(column) > sizes[p]:
                sizes[p] = len(column)+3

    f.seek(0)
    trow = 0
    table = Frame(window)
    for record in handle:
        for w,column in enumerate(record):
            print(w)
            setText = StringVar()
            Entry(table,textvariable=setText,width=sizes[w]+5,relief="groove",justify=LEFT, background='white').grid(column=w,row=trow,sticky=W)
            setText.set(column)

        trow+=1
    return table

def delete_row():
    l=list(table.grid_slaves(row=trow))
    print(l)
    for w in l:
        w.grid_forget()

def new_row():
    global trow
    for w,column in enumerate(record):
        Entry(table,textvariable="",width=sizes[w]+5,relief="groove",justify=LEFT, background='white').grid(column=w,row=trow,sticky=W)
        print (trow)
    trow+=1

root = Tk()
f = open("example.csv")
newButton = Button(text='new row', command=new_row)
deleteButton = Button(text='delete row', command='delete_row')
newtable = createStandardTable(f,root)
newtable.pack()
newButton.pack()
deleteButton.pack()
root.mainloop()

example.csv看起来像这样:

ID  | Name | username | password
1234| Bob  | test123  | l98762

当"新行"按下按钮它成功创建了一个新行。但是,每当"删除行"按下按钮它不会删除最近的行,我不明白为什么不行?

有人可以解释一下是什么错吗? 感谢。

1 个答案:

答案 0 :(得分:0)

我无法测试它,因为你没有提供一个工作示例,但我注意到的第一件事是你在添加行之后增加trow ,所以最后一行是trow - 1.因为在尝试删除之前,无论如何都需要减少它。

def delete_row():
    trow -= 1
    l=list(table.grid_slaves(row=trow))
    for w in l:
        w.grid_forget()

或者更好的是,忘记使用自己的变量并使用table.grid_size()查找要添加或删除的行。

编辑:你似乎也在向按钮传递一个字符串而不是一个函数。将该行更改为:

deleteButton = Button(text='delete row', command=delete_row)