2014-12-11 57 views
0

我建立了一个简单的待办事项列表,我试图让该复选框清除自身时则检查checkbutton(以表示任务已经完成)如何删除当检查

我不知道我需要如何执行该功能才能自行移除。任何人都可以帮助我解决这个问题。我梳理了一系列的页面,没有一个真的表明你是如何做到这一点的。

class App(object): 

def __init__(self, master): 
    self.master = master 
    self.frame = Frame(master) 
    self.frame.grid() 
    self.addFrame = Frame(master) 
    self.addFrame.grid(row=0, column=0, columnspan=2, sticky='N') 
    self.listFrame = Frame(master) 
    self.listFrame.grid(row=1, column=0, columnspan=2, sticky='NW') 
    self.todoList = [] 
    self.initUI() 

def initUI(self): 

    self.entryBox = Entry(self.frame, width = 15) 
    self.entryBox.grid(row=0, column=0, sticky='N') 

    self.addButton = Button(self.frame, text="<-ADD->", command=self.add) 
    self.addButton.grid(row=0, column=1, sticky='N') 


def removeCheckButton(self): 
    # - CONFUSED HOW TO REMOVE THE SPECIFIC CHECKBUTTON 
    pass 

def add(self): 
    entry = self.entryBox.get() 
    self.entryBox.delete(0, END) 
    self.todoList.append(entry) 
    print self.todoList 
    var1 = IntVar() 
    self.buttonList = [] 
    for n in range(len(self.todoList)): 
     lx = Checkbutton(self.listFrame, text=self.todoList[n], variable=self.todoList[n], command=removeCheckButton) 
     lx.grid(row=n, column=0, sticky='NW') 
     self.buttonList.append(lx) 
     print self.buttonList 
+0

作为第一条评论:'command = removeCheckButton'应该是'command = self.removeCheckButton'。 – Marcin 2014-12-11 03:00:26

+0

在大多数窗口小部件AFAIK上,您可以使用destroy()或grid_forget()。要做到这一点,你将不得不使用partial来将数字传递给函数,然后销毁/忘记self.buttonList [数字]。尝试一下,看看你是如何做到的。从functools中导入部分内容,并使用command = partial(self.removeCheckButton,number)调用该函数。有关grid_forget的信息,请访问http://effbot.org/tkinterbook/grid.htm – 2014-12-11 03:04:36

+0

我认为我仍然无法理解如何实施该破坏。林不知道如何通过列表中的号码 – mGarsteck 2014-12-11 03:13:47

回答

1

看看这个。你的add是有点奇怪的设计(和不正确的国际海事组织),所以我稍微修改它以及其他部分。

from tkinter import * 


class App(object): 

    def __init__(self, master): 
     self.master = master 
     self.frame = Frame(master) 
     self.frame.grid() 
     self.addFrame = Frame(master) 
     self.addFrame.grid(row=0, column=0, columnspan=2, sticky='N') 
     self.listFrame = Frame(master) 
     self.listFrame.grid(row=1, column=0, columnspan=2, sticky='NW') 
     self.todoList = [] 
     self.buttonList = [] #<--- button list is here now 
     self.initUI() 

    def initUI(self): 

     self.entryBox = Entry(self.frame, width = 15) 
     self.entryBox.grid(row=0, column=0, sticky='N') 

     self.addButton = Button(self.frame, text="<-ADD->", command=self.add) 
     self.addButton.grid(row=0, column=1, sticky='N') 


    def removeCheckButton(self, button_no): 
     # - CONFUSED HOW TO REMOVE THE SPECIFIC CHECKBUTTON 
     # print(button_no, self.buttonList[button_no]) 
     #self.buttonList[button_no].grid_forget() 
     self.buttonList[button_no].destroy() 
     # del self.buttonList[button_no] 
     # del self.todoList[button_no] 


    def add(self): 
     entry = self.entryBox.get() 
     self.entryBox.delete(0, END) 
     self.todoList.append(entry) 
     print(self.todoList) 
     var1 = IntVar() 
     #self.buttonList = [] #<--- not sense having this here 
     # for n in range(len(self.todoList)): #<-- this for also very strange here. 
     n = len(self.buttonList) 
     lx = Checkbutton(self.listFrame, 
         text=self.todoList[n], 
         variable=self.todoList[n], 
         command=lambda ni=n: self.removeCheckButton(ni)) 
     lx.grid(row=n, column=0, sticky='NW') 
     self.buttonList.append(lx) 
     # print(self.buttonList) 


root = Tk() 
app = App(root) 
root.mainloop() 

P.S. 我使用python 3,但除了import part,代码应该为您执行。可能需要更多的修复,但复选框会按照他们的设想被破坏。

+0

感谢您的帮助! 只要修复,你还会提供什么?我给了自己这个项目,以更好地学习该计划。任何建议显然都被接受。 – mGarsteck 2014-12-11 03:35:55

+0

不用担心。我没有详细介绍该计划的所有细节。我只专注于复选框的销毁。检查它是否有效,根据你的喜好进行修改,如果你有新的问题/问题,只是提出新的问题。一件很简单的事情是,当你销毁一个checkboox时,可能还需要从'self.todoList'和'self.buttonList'中去掉相关的元素。 – Marcin 2014-12-11 03:47:04

+0

我在checkbutton行上发现列表超出范围错误 – mGarsteck 2014-12-11 03:59:45

相关问题