• 为了学习python3.5的tkinter,于是我去官网找了找相关部件的一些文档,读起来有点绕口,觉得还是自己来实践实践,看看视频感觉用处会更大,然后就有了下面的一部分常用的总结,
  • 查看tkinter类库发现它主要是分为两个部分,一个是Widget classes(部件类),另一个是Mixins(多重继承,也有人说是混入)。首先我们来介绍一下Widget classes(部件类)。
  • 主要参考资料:python中tkinter库中的pack方法中optinon选项含义:http://www.cnblogs.com/zhangpengshou/p/3626137.html
  • Widget classes()
    •   Button Widget

      •   Button就像是一个按钮键,它的下面一般是藏着各种方法用来实现python的一定的功能,我们可以通过给Button写一个text的内容就会实现一个东西了。
      •   Button中的一些样式
         #coding=gbk
        from tkinter import *
        master =Tk()
        def callback():
        print('click!')
        #最普通的返回操作,按钮返回一个值(通过一个函数传递)
        #b=Button(master,text='OK',command=callback) #DISABLED state状态 表示不能按下这个按钮,无法操作这个按钮
        #b = Button(master, text="Help", state=DISABLED) #当你不设置大小的时候,按钮能容纳所有东西;当然你也可以指定大小:padx,pady
        #b = Button(master, text="Help", state=DISABLED,padx=59,pady=99) #当然我们也可以在按钮里面在写入一个窗体,窗体一般是用像素来表示的,所以按钮也是可以按照像素来进行表示的,位图也是可以的
        # f = Frame(master, height=320, width=320)
        # f.pack_propagate(0) # don't shrink
        # f.pack()
        # b = Button(f, text="Sure!")#将窗体导入
        # b.pack(fill=BOTH, expand=1)#填充顶部,扩展 #当text有多行的时候
        #b = Button(master, text='longtext阿士大夫撒旦法士大夫撒旦法', anchor=W, justify=LEFT, padx=2) #这个操作是让按钮好像已经按下去了但是实际上没有触发按钮的功能,再点击就能触发
        #b.config(relief=SUNKEN) #b = Checkbutton(master, image=, variable='var', indicatoron=0)
        #b = Button(master, text="Click me", image='pattern', compound=CENTER) b.pack() mainloop()
      •   Button中的窗口部件的选项
         #coding=gbk
        
         activebackground, activeforeground:当按钮被激活时所使用的颜色
        anchor:控制按钮上内容的位置。使用N, NE, E, SE, S, SW, W, NW, or CENTER这些值之一。默认值是CENTER。
        background (bg), foreground (fg):按钮的颜色。默认值与特定平台相关。
        bitmap:显示在窗口部件中的位图。如果image选项被指定了,则这个选项被忽略。下面的位图在所有平台上都有 效:error, gray75, gray50, gray25, gray12, hourglass, info, questhead, question, 和 warning. borderwidth (bd):按钮边框的宽度。默认值与特定平台相关。但通常是1或2象素。
        command:当按钮被按下时所调用的一个函数或方法。所回调的可以是一个函数、方法或别的可调用的Python对象。
        cursor:当鼠标移动到按钮上时所显示的光标。
        default:如果设置了,则按钮为默认按钮。
        disabledforeground:当按钮无效时的颜色。
        image:在部件中显示的图象。如果指定,则text和bitmap选项将被忽略。
        justify:定义多行文本如何对齐。可取值有:LEFT, RIGHT, 或 CENTER。
        padx, pady:指定文本或图象与按钮边框的间距。
        state:按钮的状态:NORMAL, ACTIVE 或 DISABLED。默认值为NORMAL。
        relief:边框的装饰。通常按钮按下时是凹陷的,否则凸起。另外的可能取值有GROOVE, RIDGE, 和 FLAT。
        text:显示在按钮中的文本。文本可以是多行。如果bitmaps或image选项被使用,则text选项被忽略
        textvariable:
        underline:在文本标签中哪个字符加下划线。默认值为-1,意思是没有字符加下划线
        width, height:按钮的尺寸。如果按钮显示文本,尺寸使用文本的单位。如果按钮显示图象,尺寸以象素为单位(或屏幕的单位)。如果尺寸没指定,它将根据按钮的内容来计算。
    •   Label Widget
      •   用来显示文字或者图片
      •   一些样式
         #coding=gbk
        from tkinter import *
        master = Tk() #w = Label(master, text="Hello, world!") # w = Label(master, text="Rouge", fg="red")
        # w = Label(master, text="Helvetica", font=("Helvetica", 16)) # w = Label(master, text=longtext, anchor=W, justify=LEFT) # v = StringVar()
        # Label(master, textvariable=v).pack()
        # v.set("New Text!") b.pack()
        mainloop()
      •   部件选项和Button相同
    •   Canvans Widget
      •   用来提供划线功能
      •   样式
         #coding=gbk
        from tkinter import *
        master = Tk() w = Canvas(master, width=200, height=100)
        w.pack()
        #
        # w.create_line(0, 0, 200, 100)
        # w.create_line(0, 100, 200, 0, fill="red", dash=(4, 4))
        #
        # w.create_rectangle(50, 25, 150, 75, fill="blue") mainloop()
      •   部件
         Canvas(root,bg):构造方法,在root上创建画布,root是母控件,bg是背景色,用字符串设定,例如bg='white'
        
         create_rectancle(x1,y1,x2,y2[,fill,outline,width,stipple,dash,tags]):
        
            创建一个item对象,形状是矩形,即在Canvas对象画矩形,x1,y1,x2,y2是坐标,是前4个参数,后面的参数顺序是乱来的。fill表示item的填充颜色,凡是颜色都用字符串设定,outline表示边框线的颜色,width表示边框线的宽度,dash如果缺省,则边框线是实线,否则用一个1到255的整数表示,设定虚线的长度,一般用10即可,stipple可以在图形中加入斑点,一般参数是'gray12','gray25'这样,暂时不太清楚,一般省略。tags可以是一个字符串或元组.列表等,使用后创建的item对象的tags字段就设定了,可用来作为标识寻找该item,也可以用Canvas.gettags(item)返回item的tags字段。注意tags如果是一个序列,则元组中任一元素都可以作为标识符,也就是有多个标识符。该方法返回一个编号,而不是item对象本身,编号表示该item是Canvas的第几个item。
        
         coords(item,position):
        
             移动一个item(即画好的图形)的位置,item为移动的对象,position是一个元组,4个整数表示移动后的坐标。
        
         find_withtag(tag):
        
             返回一个元组,表示所有以tag为标识符的Item对象。item对象返回后不是一个对象而是一个整数,代表是Canvas对象的第几个item而已。即使不用该方法,直接print(item),或item回车,显示的也是item对象的编号,比如1,2,3这些而已。
        
         itemconfig(item[,item类的其他参数,参见create_rectancle):
        
             设置item的各个参数,注意item可以用编号表示。
        
         move(item,x,y):
        
             把item移动,坐标增量为x,y
        
         del(item or tag):
        
             删除一个item,可用item编号(整数)或tag(字符串)
        
         scale(item,xoffset,yoffset,xscale,yscale):
        
             保持第一个端点不变,把变长,变为:(原边长 - offset)*scale + offset。简单的用法是offset全部为0,只改变变长的倍数
        
         tag_bind(tag,buttonType,methor):
        
             绑定事件与方法。当拥有tag标签的item的边框被点击时,会调用Methor,buttonType用字符串表示,设定点击的键,常用的'<Button-1>'表示鼠标左键,'<Button-3>'表示鼠标右键
        
         除了绘制矩形外,还有弧形,支线,文字,位图(一些图标),图像文件等都可以绘制,具体看说明,不再详细记录。
    •   Frame Widget
      •   样式

             #构造函数
        __init__(self, vgap=0, hgap=0)
        (Constructor) Constructor, with optional parameters to specify the gap between the rows and columns. Parameters:
        vgap
        (type=int) hgap
        (type=int) #添加单个构件到boxsizer
        # pos 表示的单元格的点(cell position可以看做是坐标)
        # span 表示的单个或合并的单元格
        Add(self, item, pos, span=DefaultSpan, flag=0, border=0, userData=None) Adds an item to the sizer at the grid cell pos, optionally spanning more than one row or column as specified with span. The remaining args behave similarly to wx.Sizer.Add. Returns True if the item was successfully placed at the given cell position, False if something was already there. Parameters:
        pos
        (type=GBPosition) span
        (type=GBSpan) flag
        (type=int) border
        (type=int)
        .
        .
        .
        (原文: http://www.wxpython.org/docs/api/wx.GridBagSizer-class.html)
      •   部件实例测试
             def __init__(self, parent):
        wx.Panel.__init__(self, parent, -1, wx.DefaultPosition, wx.DefaultSize)
        wred = wx.TextCtrl(self, wx.NewId(), 'red')
        wwhite = wx.TextCtrl(self, wx.NewId(), 'white')
        wblue = wx.TextCtrl(self, wx.NewId())
        wcyan = wx.TextCtrl(self, wx.NewId()) vgap, hgap = 10, 20
        gbs = wx.GridBagSizer(vgap, hgap) b = 0
        # Add(self, item, pos, span=DefaultSpan, flag=0, border=0, userData=None)
        # pos (type=GBPosition) cell position
        # span(type=GBSPan)
        gbs.Add(wred, (1, 1), (1, 1), wx.EXPAND | wx.ALL, b)
        gbs.Add(wwhite, (2, 3), (1, 1), wx.EXPAND | wx.ALL, b)
        gbs.Add(wblue, (1, 0), (1, 1), wx.EXPAND | wx.ALL, b)
        gbs.Add(wcyan, (0, 0), (1, 1), wx.EXPAND | wx.ALL, b) gbs.AddGrowableRow(0) # 0/1/2...表示的行号或列号
        gbs.AddGrowableRow(1)
        gbs.AddGrowableRow(2)
        gbs.AddGrowableCol(0)
        gbs.AddGrowableCol(1)
        gbs.AddGrowableCol(3) self.SetSizer(gbs)
      •   详细测试
    •   Entry Widget详解
      •   Entry用来输入单行文本

         #Tkinter教程之Entry篇
        #Entry用来输入单行文本
        '''1.第一个Entry程序'''
        from Tkinter import *
        root = Tk()
        Entry(root,text = 'input your text here').pack()
        root.mainloop()
        #上面的代码目的是创建一个Entry对象,并在Entry上显示'input your text here',运行此代码,并没有看到文本的显示,由此可知与Lable和Button不同,Entry的text属性不可以设置Entry的文本 '''2.在Entry中设定初始值,使用textvariable将变量与Entry绑定'''
        from Tkinter import *
        root = Tk()
        e = StringVar()
        entry = Entry(root,textvariable = e)
        e.set('input your text here')
        entry.pack()
        root.mainloop() #上面的例子中将变量e与Entry绑定,然后将e的值设置为'input your text here',程序运行时的初始值便设置了。 '''3.设置为只读Entry.
        Entry的另一个比较有用的属性,设置为只读,不允许用户对它的值改变。
        设置state属性为'readonly'
        '''
        from Tkinter import *
        root = Tk()
        e = StringVar()
        entry = Entry(root,textvariable = e)
        e.set('input your text here')
        entry.pack()
        entry['state'] = 'readonly'
        root.mainloop() #实际上Entry的属性值可以使用的也为normal/active/disabled,'readonly'与disabled一样 '''4.设置为密码输入框
        #将Entry作为一个密码输入框来使用,即不显示用户输入的内容值,用特定符号代替。使用用属性
        show来指定。
        '''
        from Tkinter import *
        root = Tk()
        e = StringVar()
        entry = Entry(root,textvariable = e)
        e.set('input your text here')
        entry.pack()
        #使用*来显示输入的内容,如果喜欢可以改为其它字符
        entry['show'] = '*'
        #分别使用*#$显示输入的文本内容
        for mask in ['*','#','$']:
        e = StringVar()
        entry = Entry(root,textvariable = e)
        e.set('password')
        entry.pack()
        entry['show'] = mask root.mainloop() '''5.验证输入的内容是否符合要求。
        使用validate来校验输入的内容
        使用validate方法来限制输入的内容
        这是一个有问题的例子,无法调用validateText回调函数
        ‘'''
        from Tkinter import *
        root = Tk()
        e = StringVar()
        def validateText(contents):
        print contents
        return contents.isalnum() entry = Entry(root,validate = 'key',textvariable = e,validatecommand = validateText)
        entry.pack() root.mainloop()
        '''
        文档中说明使用validate来接受的事件,使用validatecommand来确定输入的内容是否合法,但
        如何传入参数?没找到相应的说明
        '''
        #还有其他的属性fg/bg/relief/width/height/justify/state使用方法与Button相同,不再举例。 #author: jcodeer
        #blog: jcodeer.cublog.cn
        #email: jcodeer@126.com
    •   Menu Widget详解
      •   Menu是用来建立菜单的

         #coding=gbk
        from tkinter import *
        # root = Tk()
        # def hello():
        # print ("hello menu")
        # menubar = Menu(root)
        # #创建主菜单,每个菜单对应的回调函数都是hello
        # for item in ['Python','PHP','CPP','C','Java','JavaScript','VBScript']:
        # #添加菜单函数
        # menubar.add_command(label = item,command = hello)
        # #将root的menu属性设置为menubar
        # root['menu'] = menubar
        # root.mainloop() # root = Tk()
        # def hello():
        # print ('hello menu')
        # menubar = Menu(root)
        #
        # filemenu = Menu(menubar,tearoff = 0)
        # for item in ['Python','PHP','CPP','C','Java','JavaScript','VBScript']:
        # #添加菜单函数
        # filemenu.add_commad(label = item,command = hello)
        # #将menubar的menu属性指定为filemenu,即filemenu为menubar的下拉菜单
        # menubar.add_cascade(label = 'Language',menu = filemenu)
        # root['menu'] = menubar
        # root.mainloop() # '''3.向菜单中添加Checkbutton项'''
        # # -*- coding: cp936 -*-
        # from Tkinter import *
        # root = Tk()
        #每次打印出各个变量的当前值
        # root = Tk()
        # #每次打印出各个变量的当前值
        # def printItem():
        # print ('Python = '),vPython.get()
        # print ('PHP = '),vPHP.get()
        # print ('CPP = '),vCPP.get()
        # print ('C = '),vC.get()
        # print ('Java = '),vJava.get()
        # print ('JavaScript = '),vJavaScript.get()
        # print ('VBScript = '),vVBScript.get()
        #
        # menubar = Menu(root)
        #
        # vPython = StringVar()
        # vPHP = StringVar()
        # vCPP = StringVar()
        # vC = StringVar()
        # vJava = StringVar()
        # vJavaScript = StringVar()
        # vVBScript = StringVar()
        #
        # filemenu = Menu(menubar,tearoff = 0)
        # for k,v in {'Python':vPython,
        # 'PHP':vPHP,
        # 'CPP':vCPP,
        # 'C':vC,
        # 'Java':vJava,
        # 'JavaScript':vJavaScript,
        # 'VBScript':vVBScript}.items():
        # #绑定变量与回调函数
        # filemenu.add_checkbutton(label = k,command = printItem,variable = v)
        # #将menubar的menu属性指定为filemenu,即filemenu为menubar的下拉菜单
        # menubar.add_cascade(label = 'Language',menu = filemenu)
        # root['menu'] = menubar
        # root.mainloop()
        #程序运行,使用了Checkbutton,并通过printItem将每个Checkbutton在当前值打印出来。 # '''4.向菜单 中添加Radiobutton项'''
        #
        # root = Tk()
        #
        # menubar = Menu(root)
        # vLang = StringVar()
        # #每次打印出当前选中的语言
        # def printItem():
        # print ('vLang = '),vLang.get()
        # filemenu = Menu(menubar,tearoff = 0)
        # for k in ['Python','PHP','CPP','C','Java','JavaScript','VBScript']:
        # #绑定变量与回调函数,指定的变量vLang将这几项划为一组
        # filemenu.add_radiobutton(label = k,command = printItem,variable = vLang)
        # #将menubar的menu属性指定为filemenu,即filemenu为menubar的下拉菜单
        # menubar.add_cascade(label = 'Language',menu = filemenu)
        # root['menu'] = menubar
        # root.mainloop()
        # #程序每次打印出当前选中的语言
        # #与Checkbutton不同的是,同一个组内只有一个处于选中状态。 '''5.向菜单中添加分隔符'''
        # # -*- coding: cp936 -*-
        #
        # root = Tk()
        # menubar = Menu(root)
        #
        # #每次打印出当前选中的语言
        # def printItem():
        # print ('add_separator')
        #
        # filemenu = Menu(menubar,tearoff = 0)
        # for k in ['Python','PHP','CPP','C','Java','JavaScript','VBScript']:
        # filemenu.add_command(label = k,command = printItem)
        # #将各个菜单项使用分隔符隔开
        # filemenu.add_separator()
        # menubar.add_cascade(label = 'Language',menu = filemenu)
        # root['menu'] = menubar
        # root.mainloop()
        # #分隔符将相关的菜单项进行分组,只是UI上的实现,程序上没有任何改变,它也不执行任何的命令 ''' 6.将以上的例5中的菜单改为右击弹出菜单'''
        #方法是通过绑定鼠标右键,每当点击时弹出这个菜单,去掉与root的关联
        # -*- coding: cp936 -*- # root = Tk()
        # menubar = Menu(root)
        #
        # def printItem():
        # print ('popup menu')
        #
        # filemenu = Menu(menubar,tearoff = 0)
        # for k in ['Python','PHP','CPP','C','Java','JavaScript','VBScript']:
        # filemenu.add_command(label = k,command = printItem)
        # filemenu.add_separator()
        # menubar.add_cascade(label = 'Language',menu = filemenu)
        # #此时就不要将root的menu设置为menubar了
        # #root['menu'] = menubar
        # def popup(event):
        # #显示菜单
        # #这里设置右键点击显示菜单
        # menubar.post(event.x_root,event.y_root)
        # #在这里相应鼠标的右键事件,右击时调用popup,此时与菜单绑定的是root,可以设置为其它的控件,在绑定的控件上右击就可以弹出菜单
        # root.bind('<Button-3>',popup)
        # root.mainloop()
        # #运行测试一个,可以看到各个菜单 项的功能都是可以使用的,所以弹出菜单与一般的菜单功能是一样的,只是弹出的方式不同而已。 ''' 7.以下的代码演示了菜单项的操作方法,包括添加各种菜单项,删除一个或多个菜单项'''
        # -*- coding: cp936 -*- root = Tk()
        menubar = Menu(root) def printItem():
        print ('add_separator') filemenu = Menu(menubar,tearoff = 0)
        for k in range(5):
        filemenu.add_command(label = str(k),command = printItem)
        menubar.add_cascade(label = 'Language',menu = filemenu) '''以下为向菜单中添加项的操作'''
        #在索引1添加一菜单command项
        filemenu.insert_command(1,label = '',command = printItem)
        #在索引2添加一菜单checkbutton项
        filemenu.insert_checkbutton(2,label = '',command = printItem)
        #在索引3添加一菜单radiobutton项
        filemenu.insert_radiobutton(3,label = '',command = printItem)
        #将新添加的菜单项使用分隔符隔开
        filemenu.insert_separator(1)
        filemenu.insert_separator(5) '''以下为删除菜单项的操作'''
        #删除索引6-9的菜单项
        #这两个参数是控制删除下拉列表的位置的
        filemenu.delete(4,9)
        #删除索引为0的菜单项
        filemenu.delete(0) root['menu'] = menubar
        root.mainloop()
        #分隔符将相关的菜单项进行分组,只是UI上的实现,程序上没有任何改变,它也不执行任何的命令
    •   CheckButton Widget详解
      •   Checkbutton又称为多选按钮,可以表示两种状态:On和Off,可以设置回调函数,每当点击此按钮时回调函数被调用。就是相当于勾选框一样

         #coding=gbk
        '''1.一个简单的Checkbutton例子'''
        #创建一个Checkbutton,显示文本为"python"
        from tkinter import *
        # root = Tk()
        # Checkbutton(root,text = 'python').pack()
        # root.mainloop() '''2.设置Checkbutton的回调函数'''
        # def callCheckbutton():
        # print ('you check this button')
        # root = Tk()
        # Checkbutton(root,text = 'check python',command = callCheckbutton).pack()
        # root.mainloop()
        # #不管Checkbutton的状态如何,此回调函数都会被调用 '''3.通过回调函数改变Checkbutton的显示文本text的值''' # def callCheckbutton():
        # #改变v的值,即改变Checkbutton的显示值
        # v.set('check Tkinter')
        #
        # root = Tk()
        # v = StringVar()
        # v.set('check python')
        # #绑定v到Checkbutton的属性textvariable
        # Checkbutton(root,text = 'check python',textvariable = v,command = callCheckbutton).pack()
        #
        # root.mainloop() '''4.上述的textvariable使用方法与Button的用法完全相同,使用此例是为了区别Checkbutton的另外的一个属性variable,此属性与textvariable不同,它是与这个控件本身绑定,Checkbutton自己有值:On和Off值,缺省状态On为1,Off为0,如:'''
        # #显示Checkbutton的值
        # root = Tk()
        # #将一整数与Checkbutton的值绑定,每次点击Checkbutton,将打印出当前的值
        # v = IntVar()
        # def callCheckbutton():
        # print (v.get())
        # Checkbutton(root,
        # variable = v,
        # text = 'checkbutton value',
        # command = callCheckbutton).pack()
        # root.mainloop() '''5.Checkbutton的值不仅仅是1或0,可以是其他类型的数值,可以通过onvalue和offvalue属性设置Checkbutton的状态值,如下代码将On设置为'python',Off值设置为'Tkinter',程序的打印值将不再是0或1,而是'Tkinter’或‘python’'''
        # root = Tk()
        # #将一字符串与Checkbutton的值绑定,每次点击Checkbutton,将打印出当前的值
        # v = StringVar()
        # def callCheckbutton():
        # print (v.get())
        # Checkbutton(root,
        # variable = v,
        # text = 'checkbutton value',
        # onvalue = 'python', #设置On的值
        # offvalue = 'tkinter', #设置Off的值
        # command = callCheckbutton).pack()
        # root.mainloop() # 6.还有其他的属性fg/bg/relief/width/height/justify/state使用方法与Button相同,不再举例。
    •   RadioButton Widget详解
      •   Radiobutton为单选按钮,即在同一组内只能有一个按钮被选中,每当选中组内的一个按钮时,其它的按钮自动改为非选中态,与其他控件不同的是:它有组的概念

         #coding=gbk
        '''1.创建一个简单的Radiobutton'''
        from tkinter import *
        # root = Tk()
        # Radiobutton(root,text = 'python').pack()
        # Radiobutton(root,text = 'tkinter').pack()
        # Radiobutton(root,text = 'widget').pack()
        # root.mainloop()
        # #不指定绑定变量,每个Radiobutton自成一组 '''2.创建一个Radiobutton组,使用绑定变量来设置选中哦的按钮'''
        # root = Tk()
        # #创建一个Radiobutton组,创建三个Radiobutton,并绑定到整型变量v
        # #选中value=1的按钮
        # v = IntVar()
        # v.set(1)
        # for i in range(3):
        # Radiobutton(root,variable = v,text = 'python',value = i).pack()
        # root.mainloop() '''3.创建两个不同的组'''
        # root = Tk()
        # vLang = IntVar()
        # vOS = IntVar()
        # vLang.set(1)
        # vOS.set(2)
        #
        # for v in [vLang,vOS]: #创建两个组
        # for i in range(3): #每个组含有3个按钮
        # Radiobutton(root,
        # variable = v,
        # value = i,
        # text = 'python' + str(i)
        # ).pack()
        # root.mainloop()
        # #不同的组,各个按钮互不影响。 '''4.如果同一个组中的按钮使用相同的alue,则这两个按钮的工作方式完全相同''' root = Tk()
        v = IntVar()
        v.set(1)
        for i in range(3):
        Radiobutton(root,
        variable = v,
        value = 1,
        text = 'python' + str(i)
        ).pack()
        for i in range(3):
        Radiobutton(root,
        variable = v,
        value = i,
        text = 'python' + str(2 + i)
        ).pack()
        root.mainloop()
        #上述的例子中共有4个alue为1的值,当选中其中的一个时,其他三个也会被选中;选中除了这四个只外的按钮时,四个按钮全部取消 '''5.与Checkbutton类似,每个Radiobutton可以有自己的处理函数,每当点击按钮时,系统会调用相应的处理函数'''
        # -*- coding: cp936 -*- # root = Tk()
        # v = IntVar()
        # v.set(0)
        # def r1():
        # print ('call r1')
        # def r2():
        # print ('call r2')
        # def r3():
        # print ('call r3')
        # def r4():
        # print ('call r4')
        # i = 0
        # #创建8个按钮,其中两个两个的value值相同
        # for r in [r1,r2,r3,r4]:
        # Radiobutton(root,
        # variable = v,
        # text = 'radio button',
        # value = i,
        # command = r
        # ).pack()
        # Radiobutton(root,
        # variable = v,
        # text = 'radio button',
        # value = i,
        # command = r
        # ).pack()
        # i += 1
        #
        # root.mainloop()
        # #注意虽然同时可以选中两个按钮,但每次点击按钮,执行的代码只有一次
    •   LsitBox Widget详解
      • Listbox为列表框控件,它可以包含一个或多个文本项(text item),可以设置为单选或多选

         '''1.创建一个Listbox,向其中添加三个item'''
        from Tkinter import *
        root = Tk()
        lb = Listbox(root)
        for item in ['python','tkinter','widget']:
        lb.insert(END,item)
        lb.pack()
        root.mainloop() '''2.创建一个可以多选的Listbox,使用属性selectmaod'''
        from Tkinter import *
        root = Tk()
        lb = Listbox(root,selectmode = MULTIPLE)
        for item in ['python','tkinter','widget']:
        lb.insert(END,item)
        lb.pack()
        root.mainloop()
        # 依次点击这三个item,均显示为选中状态。
        # 属性MULTIPLE允许多选,每次点击item,它将改变自己的当前选状态,与Checkbox有点相似 '''3这个属性selectmode还可以设置为BROWSE,可以通过鼠标来移动Listbox中的选中位置(不是移动item),这个属性也是Listbox在默认设置的值,这个程序与1.程序运行的结果的一样的。'''
        from Tkinter import *
        root = Tk()
        lb = Listbox(root,selectmode = BROWSE)
        for item in ['python','tkinter','widget']:
        lb.insert(END,item)
        lb.pack()
        root.mainloop()
        #使用鼠标进行拖动,可以看到选中的位置随之变化。
        # 与BROWSE相似 的为SINGLE,但不支持鼠标移动选中位置。
        from Tkinter import *
        root = Tk()
        lb = Listbox(root,selectmode = BROWSE)
        for item in ['python','tkinter','widget']:
        lb.insert(END,item)
        lb.pack()
        root.mainloop()
        #使用鼠标进行拖动,没有任何变化
        '''4.使用selectmode = EXPANDED使用Listbox来支持Shift和Control。'''
        from Tkinter import *
        root = Tk()
        lb = Listbox(root,selectmode = EXTENDED)
        for item in ['python','tkinter','widget']:
        lb.insert(END,item)
        lb.pack()
        root.mainloop()
        #运行程序,点中“python",shift + 点击"widget",会选中所有的item
        #运行程序,点中"python",control + 点击"widget",会选中python和widget,第二项tkinter处于非选中状态 '''5.向Listbox中添加一个item'''
        # 以上的例子均使用了insert来向Listbox中添加 一个item,这个函数有两个属性一个为添加的索引值,另一个为添加的项(item)
        # 有两个特殊的值ACTIVE和END,ACTIVE是向当前选中的item前插入一个(即使用当前选中的索引作为插入位置);END是向
        # Listbox的最后一项添加插入一项
        # 先向Listbox中追加三个item,再在Listbox开始添加三项
        from Tkinter import *
        root = Tk()
        lb = Listbox(root)
        for item in ['python','tkinter','widget']:
        lb.insert(END,item)
        #只添加一项将[]作为一个item
        #lb.insert(0,['linux','windows','unix'])
        #添加三项,每个string为一个item
        lb.insert(0,'linux','windows','unix')
        lb.pack()
        root.mainloop()
        '''6.删除Listbox中的项,使用delete,这个函数也有两个参数,第一个为开始的索引值;第二个为结束的索引值,如果不指定则只删除第一个索引项。'''
        from Tkinter import *
        root = Tk()
        lb = Listbox(root)
        for i in range(10):
        lb.insert(END,str(i))
        lb.delete(1,3)
        lb.pack()
        root.mainloop()
        #运行程序,只有值0456789,1-3被删除
        #删除全部内容,使用delete指定第一个索引值0和最后一个参数END,即可
        #lb.delete(0,END)
        '''7.选中操作函数,使用函数实现。selection_set函数有两个参数第一个为开始的索引;第二个为结束的索引,如果不指定则只选中第一个参数指定的索引项'''
        from Tkinter import *
        root = Tk()
        lb = Listbox(root)
        for i in range(10):
        lb.insert(END,str(i))
        lb.selection_set(0,10)
        lb.pack()
        root.mainloop()
        # 程序运行结果,选中了所有的项。 此代码并未指定Listbox为MULTIPLE或EXTENDED,查通过selection_set仍旧可以对Listbox
        #进行操作。 #与之相对的便是取消选中的函数了,参数与selection_set在参数相同,如下代码取消索引从0-3在状态
        from Tkinter import *
        root = Tk()
        lb = Listbox(root)
        for i in range(10):
        lb.insert(END,str(i))
        lb.selection_set(0,10)
        lb.selection_clear(0,3)
        lb.pack()
        root.mainloop() '''8.得到当前Listbox中的item个数'''
        from Tkinter import *
        root = Tk()
        lb = Listbox(root)
        for i in range(10):
        lb.insert(END,str(i))
        lb.delete(3)
        print lb.size()
        lb.pack()
        root.mainloop()
        #首先向Listbox中添加 了10个item,然后删除索引为3在item,最后的打印结果为9,即当前的Listbox中只有9项 '''9.返回指定索引的项'''
        from Tkinter import *
        root = Tk()
        lb = Listbox(root)
        for i in range(10):
        lb.insert(END,str(i*100))
        print lb.get(3)
        lb.pack()
        root.mainloop()
        #返回值为300
        #get也为两个参数的函数,可以返回多个项(item),如下返回索引值3-7的值
        from Tkinter import *
        root = Tk()
        lb = Listbox(root)
        for i in range(10):
        lb.insert(END,str(i*100))
        print lb.get(3,7)
        lb.pack()
        root.mainloop()
        #返回值为('300', '400', '500', '600', '700'),是一个tuple类型。 '''10.返回当前返回的项的索引,不是item的值'''
        from Tkinter import *
        root = Tk()
        lb = Listbox(root)
        for i in range(10):
        lb.insert(END,str(i*100))
        lb.selection_set(3,8)
        print lb.curselection()
        lb.pack()
        root.mainloop()
        #返回值为('3', '4', '5', '6', '7', '8'),而不是('300','400','500','600','700','800'),哑然无法直接得到各项的值,知道了索引,得到值
        #就很容易了:lb.get()就可以实现。 '''11.判断 一个项是否被选中,使用索引。'''
        from Tkinter import *
        root = Tk()
        lb = Listbox(root)
        for i in range(10):
        lb.insert(END,str(i*100))
        lb.selection_set(3,8)
        print lb.selection_includes(8)
        print lb.selection_includes(0) lb.pack()
        root.mainloop()
        #返回结果:True Flase,即8包含在选中的索引中,0不包含在选中的索引中 '''12.Listbox与变量绑定'''
        # -*- coding: cp936 -*-
        from Tkinter import *
        root = Tk()
        v = StringVar()
        lb = Listbox(root,listvariable = v)
        for i in range(10):
        lb.insert(END,str(i*100))
        #打印当前列表中的项值
        print v.get()
        #输出:('0', '100', '200', '300', '400', '500', '600', '700', '800', '900')
        #改变v的值,使用tuple可以与item对应
        v.set(('',''))
        #结果只有两项了1000和200
        lb.pack()
        root.mainloop() '''13.Listbox与事件绑定'''
        # 它不支持command属性来设置回调函数了,使用bind来指定回调函数,打印当前选中的值
        # -*- coding: cp936 -*-
        from Tkinter import *
        root = Tk()
        def printList(event):
        print lb.get(lb.curselection())
        lb = Listbox(root)
        lb.bind('<Double-Button-1>',printList)
        for i in range(10):
        lb.insert(END,str(i*100))
        lb.pack()
        root.mainloop() #还有一个比较实用的功能没有介绍:滚动条的添加,留到后面介绍Scrollbar的时候再一并介绍
    •   Message Widget详解
      •   用法和Label一样
    •   TopLevel Widget详解
      •   TopLevel与Frame类似,但它包含窗体属性(如Title)

         '''1.创建简单的Toplevel'''
        # -*- coding: cp936 -*-
        from Tkinter import *
        root = Tk()
        tl = Toplevel()
        #为了区别root和tl,我们向tl中添加了一个Label
        Label(tl,text = 'hello label').pack()
        root.mainloop()
        #运行结果生成了两个窗体,一个是root启动的,另一个则是Toplevel创建的,它包含有一个label;关闭tl
        #则没有退出程序,Tk仍旧工作;若关闭Tk,整个Tk结束tl也结束,它不能单独存在。 '''2.设置Toplevel的属性'''
        #title设置标题
        #geometry设置宽和高
        # -*- coding: cp936 -*-
        from Tkinter import *
        root = Tk()
        tl = Toplevel()
        #设置tl的title
        tl.title('hello Toplevel')
        #设置tl在宽和高
        tl.geometry('400x300')
        #为了区别root和tl,我们向tl中添加了一个Label
        Label(tl,text = 'hello label').pack()
        root.mainloop() '''3.使用Toplevel自己制作提示框'''
        # -*- coding: cp936 -*-
        from Tkinter import *
        root = Tk()
        mbYes,mbYesNo,mbYesNoCancel,mbYesNoAbort = 0,1,2,4
        #定义一个消息对话框,依据传入的参数不同,弹出不同的提示信息
        def MessageBox(): #没有使用使用参数
        mbType = mbYesNo
        textShow = 'Yes'
        if mbType == mbYes:
        textShow = 'Yes'
        elif mbType == mbYesNo:
        textShow = 'YesNo'
        elif mbType == mbYesNoCancel:
        textShow = 'YesNoCancel'
        elif mbType == mbYesNoAbort:
        textShow = 'YesNoAbort'
        tl = Toplevel(height = 200,width = 400)
        Label(tl,text = textShow).pack()
        #由Button来启动这个消息框,因为它使用了空的回调函数,故MessageBox改为了无参数形式,使用了固定
        #值mbYesNo
        Button(root,text = 'click me',command = MessageBox).pack()
        root.mainloop()

Python--详解TKinter类库的更多相关文章

  1. [转载]python 详解re模块

    原文地址:python 详解re模块作者:Rocky 正则表达式的元字符有. ^ $ * ? { [ ] | ( ) .表示任意字符 []用来匹配一个指定的字符类别,所谓的字符类别就是你想匹配的一个字 ...

  2. 33 Python 详解命令解析 - argparse--更加详细--转载

    https://blog.csdn.net/lis_12/article/details/54618868 Python 详解命令行解析 - argparse Python 详解命令行解析 - arg ...

  3. python 详解re模块

    正则表达式的元字符有. ^ $ * ? { [ ] | ( ).表示任意字符[]用来匹配一个指定的字符类别,所谓的字符类别就是你想匹配的一个字符集,对于字符集中的字符可以理解成或的关系.^ 如果放在字 ...

  4. 【经典案例】Python详解设计模式:策略模式

    完成一项任务往往有多种方式,我们将其称之为策略. 比如,超市做活动,如果你的购物积分满1000,就可以按兑换现金抵用券10元,如果购买同一商品满10件,就可以打9折,如果如果购买的金额超过500,就可 ...

  5. python 详解正则表达式的使用(re模块)

    一,什么是正则表达式 正则表达式(regular expression)描述了一种字符串匹配的模式(pattern),可以用来检查一个串是否含有某种子串.将匹配的子串替换或者从某个串中取出符合某个条件 ...

  6. python详解json模块

    我们在做工作中经常会使用到json模块,今天就简单介绍下json模块 什么是json JSON ,全称为JavaScript Object Notation, 也就是JavaScript 对象标记,它 ...

  7. Python——详解collections工具库

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天为大家介绍Python当中一个很好用也是很基础的工具库,叫做collections. collection在英文当中有容器的意思,所以顾 ...

  8. Python——详解__str__, __repr__和__format__

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是Python专题的第10篇文章,我们来聊聊Python当中的类. 打印实例 我们先从类和对象当中最简单的打印输出开始讲起,打印一个实例 ...

  9. Python——详解__slots__,property和私有方法

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是Python专题的第11篇文章,我们来聊聊面向对象的一些进阶使用. __slots__ 如果你看过github当中一些大牛的代码,你会 ...

随机推荐

  1. Network Saboteur (深搜递归思想的特殊使用)

    个人心得:对于深搜的使用还是不到位,对于递归的含义还是不太清楚!本来想着用深搜构成一个排列,然后从一到n分割成俩个数组,然后后面发现根本实现不了,思路太混乱.后来借鉴了网上的思想,发现用数组来标志,当 ...

  2. BZOJ5302: [Haoi2018]奇怪的背包

    BZOJ5302: [Haoi2018]奇怪的背包 https://lydsy.com/JudgeOnline/problem.php?id=5302 分析: 方程\(\sum\limits_{i=1 ...

  3. 2017.10.3北京清北综合强化班DAY3

    括号序列(bracket) Time Limit:1000ms   Memory Limit:128MB 题目描述 LYK有一个括号序列,但这个序列不一定合法. 一个合法的括号序列如下: ()是合法的 ...

  4. 类和对象(12)—— this指针

    首先,我们都知道类的成员函数可以访问类的数据(限定符只是限定于类外的一些操作,类内的一切对于成员函数来说都是透明的),那么成员函数如何知道哪个对象的数据成员要被操作呢,原因在于每个对象都拥有一个指针: ...

  5. Python函数-all()

    all(iterable) 作用: 如果iterable的所有元素不为0.''.False或者iterable为空,all(iterable)返回True,否则返回False:函数等价于: def a ...

  6. poj 3421 X-factor Chains——质因数分解

    题目:http://poj.org/problem?id=3421 记忆化搜索竟然水过去了.仔细一想时间可能有点不对,但还是水过去了. #include<iostream> #includ ...

  7. 蓝桥杯 算法训练 ALGO-117 友好数

    算法训练 友好数   时间限制:1.0s   内存限制:256.0MB 问题描述 有两个整数,如果每个整数的约数和(除了它本身以外)等于对方,我们就称这对数是友好的.例如: 9的约数和有:1+3=4 ...

  8. debug时打到了URLClassLoader.class里面,

    一.解决方法,查看breakpoints,看有没有在这个类里面打断点,有时会系统自动打断电在这个类里面, 二.在设置里面,找到debug,去掉debug的前面几个断电设置.

  9. 在IIS下配置自定义的报错页面

    这里介绍在IIS中配置自定义出错页面的方法,主要以404为例,其他状态可类推 1.远程桌面连接IIS所在的服务器,进入控制面板>系统和安全>管理工具,双击打开IIS管理器,选择需要配置的网 ...

  10. 开发环境入门 linux基础(部分)虚拟内存,rpm和yum安装

    虚拟内存,rpm和yum安装 文本中查找 /内容 替换:扩展模式下(:)%s /替换目标/要替换的文件/ (只替换第一个)(后边加g全部替换) :set u添加行号 raid  lvm逻辑卷 df - ...