• Python GUI


    目录:

    Tkinter 组件

      标准属性

      几何管理

    代码实例:

      1、 Label & Button

      2、 Entry & Text

      3、Listbox列表

      4、Radiobutton单选框

      5、Scale尺度

           6、Checkbutton复选框

      7、Canvas 画布

      8、Menubar菜单

         9、Frame框架

      10、messagebox弹窗

      11、pack & gird & place几何管理

           12、事件关联

           13、字体

           14、下拉列表Comobobox

           15、文件选择框filedialog

    代码实战 - 登录窗口

    Python GUI编程(Tkinter)

    Python 提供了多个图形开发界面的库,几个常用 Python GUI 库如下:

    • Tkinter: Tkinter 模块(Tk 接口)是 Python 的标准 Tk GUI 工具包的接口 .Tk 和 Tkinter 可以在大多数的 Unix 平台下使用,同样可以应用在 Windows 和 Macintosh 系统里。Tk8.0 的后续版本可以实现本地窗口风格,并良好地运行在绝大多数平台中。

    • wxPython:wxPython 是一款开源软件,是 Python 语言的一套优秀的 GUI 图形库,允许 Python 程序员很方便的创建完整的、功能键全的 GUI 用户界面。

    • Jython:Jython 程序可以和 Java 无缝集成。除了一些标准模块,Jython 使用 Java 的模块。Jython 几乎拥有标准的Python 中不依赖于 C 语言的全部模块。比如,Jython 的用户界面将使用 Swing,AWT或者 SWT。Jython 可以被动态或静态地编译成 Java 字节码。

     

    Tkinter 编程

    Tkinter 是 Python 的标准 GUI 库。Python 使用 Tkinter 可以快速的创建 GUI 应用程序。

    由于 Tkinter 是内置到 python 的安装包中、只要安装好 Python 之后就能 import Tkinter 库、而且 IDLE 也是用 Tkinter 编写而成、对于简单的图形界面 Tkinter 还是能应付自如。

    注意:Python3.x 版本使用的库名为 tkinter,即首写字母 T 为小写。

    import tkinter
    #创建一个GUI程序
    
    #1、导入 Tkinter 模块
    #2、创建控件
    #3、指定这个控件的 master, 即这个控件属于哪一个
    #4、告诉 GM(geometry manager) 有一个控件产生了。

     主窗口常用操作:

    1 root.title('标题名')#修改框体的名字,也可在创建时使用className参数来命名;
    2 root.resizable(0,0)  # 框体大小可调性,分别表示x,y方向的可变性;
    3 root.geometry('250x150')#指定主框体大小;
    4 root.quit() # 退出;
    5 root.update_idletasks()
    6 root.update()#刷新页面;

    Tkinter 组件

    Tkinter的提供各种控件,如按钮,标签和文本框,一个GUI应用程序中使用。这些控件通常被称为控件或者部件。

    目前有15种Tkinter的部件。我们提出这些部件以及一个简短的介绍,在下面的表:

    (在Tkinter中窗口部件类没有分级;所有的窗口部件类在树中都是兄弟。)

    标准属性

    标准属性也就是所有控件的共同属性,如大小,字体和颜色等等

    几何管理

    Tkinter控件有特定的几何状态管理方法,管理整个控件区域组织,一下是Tkinter公开的几何管理类:包、网格、位置

     组件的放置和排版(pack,grid,place) 属性参数

    pack组件设置位置属性参数:
        after:        将组件置于其他组件之后;
        before:       将组件置于其他组件之前;
        anchor:        组件的对齐方式,顶对齐'n',底对齐's',左'w',右'e'
        side:        组件在主窗口的位置,可以为'top','bottom','left','right'(使用时tkinter.TOP,tkinter.E);
        fill            填充方式 (Y,垂直,X,水平)
        expand          1可扩展,0不可扩展
    grid组件使用行列的方法放置组件的位置,参数有:
        column:         组件所在的列起始位置;
        columnspam:     组件的列宽;
        row:         组件所在的行起始位置;
        rowspam:      组件的行宽;
    place组件可以直接使用坐标来放置组件,参数有:
        anchor:       组件对齐方式;    NW N NE E SE S SW W CENTER
        x:            组件左上角的x坐标;
        y:             组件右上角的y坐标;
        relx:          组件相对于窗口的x坐标,应为0-1之间的小数;
        rely:           组件相对于窗口的y坐标,应为0-1之间的小数;
                  组件的宽度;
        heitht:        组件的高度;
        rel       组件相对于窗口的宽度,0-1;
        relheight:     组件相对于窗口的高度,0-1;
    View Code

    代码实例:

    1、 Label & Button

    # -*- coding: utf-8 -*-
    # @Time    : 2018/3/31 0:15
    # @Author  : TanRong
    # @Software: PyCharm
    # @File    : lable_button.py
    
    from tkinter import *
    
    root = Tk()  #根窗口
    root.title('Lable & Button') #主窗口标题
    root.geometry('800x600') #主窗口大小,中间的为英文字母x
    
    var = StringVar() #tk里面特定的字符串形式
    lable = Label(root, textvariable=var, bg='green', font=('Arial', 12),
                  width=15, height=2)
    lable.pack()
    # lable.place() 安放到具体位置
    
    on_hit = False
    def hit_me():
        global on_hit #必须标出它是global的
        if on_hit == False:
            on_hit = True
            var.set('线性回归')
        else:
            on_hit = False
            var.set('')
    
    button = Button(root, text='执行', width=15, height=2, command=hit_me)
    button.pack()
    
    root.mainloop()
    View Code
        anchor:            指定按钮上文本的位置;
        background(bg)       指定按钮的背景色;
        bitmap:            指定按钮上显示的位图;
        borderwidth(bd)    指定按钮边框的宽度;
        command:          指定按钮消息的回调函数;
        cursor:            指定鼠标移动到按钮上的指针样式;
        font:               指定按钮上文本的字体;
        foreground(fg)     指定按钮的前景色;
        height:            指定按钮的高度;
        image:             指定按钮上显示的图片;
        state:              指定按钮的状态(disabled);
        text:               指定按钮上显示的文本;
                     指定按钮的宽度
        padx               设置文本与按钮边框x的距离,还有pady;
        activeforeground    按下时前景色
        textvariable        可变文本,与StringVar等配合着用
    Button按钮的参数
        Anchor            标签中文本的位置;
        background(bg)    背景色;
        foreground(fg)      前景色;
        borderwidth(bd)     边框宽度;
        width             标签宽度;
        height            标签高度;
        bitmap             标签中的位图;
        font               字体;
        image             标签中的图片;
        justify            多行文本的对齐方式;
        text             标签中的文本,可以使用'
    '表示换行
        textvariable       显示文本自动更新,与StringVar等配合着用
    Label组件控制参数

    2、 Entry & Text

    # -*- coding: utf-8 -*-
    # @Time    : 2018/4/1 0:30
    # @Author  : TanRong
    # @Software: PyCharm
    # @File    : entry_text.py
    
    from tkinter import *
    
    root = Tk();
    root.title('Entry & Text')
    root.geometry('800x600')
    
    entry = Entry(root, show='*')
    entry.pack()
    def insert_point():
        var = entry.get()
        text.insert('insert', var)
    def insert_end():
        var = entry.get()
        # text.insert('end', var) 插入到末尾
        text.insert('2.2', var) #插入到第二行第三位
    b1 = Button(root, text='insert point', width=15, height=2, command=insert_point)
    b1.pack()
    b2 = Button(root, text='insert end', command=insert_end)
    b2.pack()
    text = Text(root, height=2)
    text.pack()
    
    root.mainloop()
    View Code
        background(bg)      文本框背景色;
        foreground(fg)        前景色;
        selectbackground    选定文本背景色;
        selectforeground    选定文本前景色;
        borderwidth(bd)      文本框边框宽度;
        font                 字体;
        show                文本框显示的字符,若为*,表示文本框为密码框;
        state               状态;
        width              文本框宽度
        textvariable        可变文本,与StringVar等配合着用
    文本框tkinter.Entry,tkinter.Text控制参数

    3、Listbox列表

     1 # -*- coding: utf-8 -*-
     2 # @Time    : 2018/4/1 0:45
     3 # @Author  : TanRong
     4 # @Software: PyCharm
     5 # @File    : listbox.py
     6 
     7 from tkinter import *
     8 
     9 root = Tk();
    10 root.title('Listbox')
    11 root.geometry('400x300')
    12 
    13 var1 = StringVar()
    14 lable = Label(root, bg='yellow', width=4, textvariable=var1)
    15 lable.pack()
    16 
    17 def print_selection():
    18     value = lb.get(lb.curselection()) #得到光标选定的列表项
    19     var1.set(value)
    20 
    21 button = Button(root, text='print selection', width=15, height=2, command=print_selection)
    22 button.pack()
    23 
    24 var2 = StringVar()
    25 var2.set((11,22,33,55))
    26 lb = Listbox(root, listvariable=var2)
    27 list_items = [1,2,3,4]
    28 for item in list_items:
    29     lb.insert('end', item)
    30 lb.insert(1, 'first') #索引插入,第2位插入first
    31 lb.insert(2, 'second')
    32 lb.delete(2)#索引删除
    33 lb.pack()
    34 
    35 root.mainloop()
    View Code

    4、Radiobutton单选框

     1 # -*- coding: utf-8 -*-
     2 # @Time    : 2018/4/1 0:59
     3 # @Author  : TanRong
     4 # @Software: PyCharm
     5 # @File    : radiobutton.py
     6 
     7 import tkinter as tk
     8 
     9 root = tk.Tk()
    10 root.title("Radiobutton")
    11 root.geometry('400x300')
    12 
    13 var = tk.StringVar()
    14 lable = tk.Label(root, text='empty', bg='yellow', width=25 )
    15 lable.pack()
    16 
    17 def print_selection():
    18     lable.config(text='you have selected ' + var.get()) #lable重新设置text
    19 r1 = tk.Radiobutton(root, text='OptionA',
    20                     variable=var, value='A',
    21                     command=print_selection)
    22 r1.pack()
    23 r2 = tk.Radiobutton(root, text='OptionB',
    24                     variable=var, value='B',
    25                     command=print_selection)
    26 r2.pack()
    27 r3 = tk.Radiobutton(root, text='OptionC',
    28                     variable=var, value='C',
    29                     command=print_selection)
    30 r3.pack()
    31 
    32 root.mainloop()
    View Code
        anchor           文本位置;
        background(bg)   背景色;
        foreground(fg)    前景色;
        borderwidth       边框宽度;
        width            组件的宽度;
        height           组件高度;
        bitmap           组件中的位图;
        image            组件中的图片;
        font             字体;
        justify          组件中多行文本的对齐方式;
        text             指定组件的文本;
        value            指定组件被选中中关联变量的值;
        variable          指定组件所关联的变量;
        indicatoron        特殊控制参数,当为0时,组件会被绘制成按钮形式;
        textvariable       可变文本显示,与StringVar等配合着用
    单选框Radiobutton控制参数

    5、Scale尺度

     1 # -*- coding: utf-8 -*-
     2 # @Time    : 2018/4/1 1:17
     3 # @Author  : TanRong
     4 # @Software: PyCharm
     5 # @File    : scale.py
     6 import tkinter as tk
     7 
     8 root = tk.Tk()
     9 root.title("Scale")
    10 root.geometry('400x300')
    11 
    12 lable = tk.Label(root, text='empty', bg='yellow', width=25 )
    13 lable.pack()
    14 
    15 def print_selection(v):
    16     lable.config(text='you have selected '+ v)
    17 #5-11是取值范围;HORIZONTAL指水平;length是长度200像素;showvalue为1是将value显示在scale上面;
    18 # tickinterval是标签的单位长度,比如隔3个数值显示一个单位;resolution=0.01保留2位小数
    19 # Scale中的执行函数是有默认传入值的,就是标签的值
    20 scale = tk.Scale(root, label='try me', from_=5, to=11,
    21                  orient=tk.HORIZONTAL, length=200,
    22                  showvalue=1, tickinterval=3, resolution=0.01,
    23                  command=print_selection)
    24 scale.pack()
    25 root.mainloop()
    View Code

    6、Checkbutton复选框

     1 # -*- coding: utf-8 -*-
     2 # @Time    : 2018/4/1 15:19
     3 # @Author  : TanRong
     4 # @Software: PyCharm
     5 # @File    : checkbutton.py
     6 
     7 import tkinter as tk
     8 
     9 root = tk.Tk()
    10 root.title('Checkbutton')
    11 root.geometry('400x300')
    12 
    13 label = tk.Label(root, bg='yellow', width=20, text='Empty')
    14 label.pack()
    15 
    16 
    17 def print_selectioin():
    18     var = tk.StringVar()
    19     if var1.get() + var2.get() == 2:
    20         var = 'I love both'
    21     elif var1.get() + var2.get() == 0:
    22         var = 'I do not love either'
    23     else:
    24         if var1.get() == 1:
    25             var = 'I love Python'
    26         else:
    27             var = 'I love C++'
    28 
    29     label.config(text=var)
    30 
    31 var1 = tk.IntVar()
    32 var2 = tk.IntVar()
    33 c1 = tk.Checkbutton(root, text='Python', variable=var1, onvalue=1, offvalue=0,
    34                     command=print_selectioin)
    35 c2 = tk.Checkbutton(root, text='C++', variable=var2, onvalue=1, offvalue=0,
    36                     command=print_selectioin)
    37 c1.pack()
    38 c2.pack()
    39 root.mainloop()
    View Code
        anchor           文本位置;
        background(bg)   背景色;
        foreground(fg)    前景色;
        borderwidth       边框宽度;
        width            组件的宽度;
        height           组件高度;
        bitmap           组件中的位图;
        image            组件中的图片;
        font             字体;
        justify          组件中多行文本的对齐方式;
        text             指定组件的文本;
        value            指定组件被选中中关联变量的值;
        variable          指定组件所关联的变量;
        indicatoron        特殊控制参数,当为0时,组件会被绘制成按钮形式;
        textvariable       可变文本显示,与StringVar等配合着用
    复选框Checkbutton控制参数

    7、Canvas 画布

     1 # -*- coding: utf-8 -*-
     2 # @Time    : 2018/4/1 16:02
     3 # @Author  : TanRong
     4 # @Software: PyCharm
     5 # @File    : canvas.py
     6 
     7 import tkinter as tk
     8 
     9 root = tk.Tk()
    10 root.title('Canvas')
    11 root.geometry('400x300')
    12 
    13 
    14 canvas = tk.Canvas(root, bg='blue', height=100, width=200)
    15 image_file = tk.PhotoImage(file='../images/23.gif')
    16 image = canvas.create_image(10, 10, anchor='nw', image=image_file) #是图片锚定的点
    17 
    18 x0,y0,x1,y1 = 50,50,80,80
    19 line = canvas.create_line(x0,y0,x1,y1)
    20 
    21 oval = canvas.create_oval(x0,y0,x1,y1,fill='red') #x0,y0,x1,y1是圆的外接正方形
    22 arc = canvas.create_arc(x0+30,y0+30,x1+30,y1+30, start=0, extent=160)#0-160角度范围
    23 rect = canvas.create_rectangle(100,30,100+20,30+20)
    24 canvas.pack()
    25 
    26 def moveit():
    27     canvas.move(rect, 1, 2)  #rect是正方形id,1是x方向移动,2是y方向移动
    28 button = tk.Button(root, text='move', command=moveit).pack()
    29 
    30 root.mainloop()
    View Code
    background(bg)      背景色;
        foreground(fg)       前景色;
        borderwidth       组件边框宽度;
        width             组件宽度;
        height             高度;
        bitmap             位图;
        image             图片;
    绘图的方法主要以下几种:
        create_arc          圆弧;
        create_bitmap      绘制位图,支持XBM;
        create_image       绘制图片,支持GIF(x,y,image,anchor);
        create_line         绘制支线;
        create_oval;        绘制椭圆;
        create_polygon     绘制多边形(坐标依次罗列,不用加括号,还有参数,fill,outline);
        create_rectangle   绘制矩形((a,b,c,d),值为左上角和右下角的坐标);
        create_text         绘制文字(字体参数font,);
        create_window      绘制窗口;
        delete              删除绘制的图形;
        itemconfig          修改图形属性,第一个参数为图形的ID,后边为想修改的参数;
        move               移动图像(1,4,0),1为图像对象,4为横移4像素,0为纵移像素,然后用root.update()刷新即可看到图像的移动,为了使多次移动变得可视,最好加上time.sleep()函数;
        只要用create_方法画了一个图形,就会自动返回一个ID,创建一个图形时将它赋值给一个变量,需要ID时就可以使用这个变量名。
        coords(ID)          返回对象的位置的两个坐标(4个数字元组);
    
    对于按钮组件、菜单组件等可以在创建组件时通过command参数指定其事件处理函数。方法为bind;或者用bind_class方法进行类绑定,bind_all方法将所有组件事件绑定到事件响应函数上。
    组图组件Canvas控制参数

    8、Menubar菜单

     1 # -*- coding: utf-8 -*-
     2 # @Time    : 2018/4/1 16:02
     3 # @Author  : TanRong
     4 # @Software: PyCharm
     5 # @File    : menubar.py
     6 import tkinter as tk
     7 
     8 root = tk.Tk()
     9 root.title("Menubar")
    10 root.geometry('400x300')
    11 
    12 label = tk.Label(root, text='', bg='yellow')
    13 label.pack()
    14 
    15 counter = 0
    16 def do_job():
    17     global counter
    18     label.config(text='do '+ str(counter))   #如果直接将pack()写在label定义的后面,则在这里就会出现label没有config属性的错误
    19     counter += 1
    20 menubar = tk.Menu(root)
    21 filemenu = tk.Menu(menubar, tearoff=0)#tearoff是指不可分割  它的值只有0和1,将tearoff设置为1以后,就是表明这个菜单是可以独立出来的,如果是0的话就不可以独立出来。代码演示一下即可。
    22 menubar.add_cascade(label='File', menu=filemenu)
    23 filemenu.add_command(label='New', command=do_job)
    24 filemenu.add_command(label='Open', command=do_job)
    25 filemenu.add_command(label='Save', command=do_job)
    26 filemenu.add_separator()
    27 filemenu.add_command(label='Exit',command=root.quit)
    28 
    29 editmenu = tk.Menu(menubar, tearoff=0)
    30 menubar.add_cascade(label='Edit', menu=editmenu)
    31 editmenu.add_command(label='Cut', command=do_job)
    32 editmenu.add_command(label='Copy', command=do_job)
    33 editmenu.add_command(label='Paste', command=do_job)
    34 
    35 submenu = tk.Menu(filemenu)
    36 filemenu.add_cascade(label='Import', menu=submenu, underline=0)
    37 submenu.add_command(label='Submenu1', command=do_job)
    38 
    39 root.config(menu = menubar) #将整个menubar添加到窗口
    40 root.mainloop()
    View Code
    参数: 
        tearoff          分窗,0为在原窗,1为点击分为两个窗口
        bg,fg           背景,前景
        borderwidth      边框宽度
        font              字体
        activebackgound   点击时背景,同样有activeforeground,activeborderwidth,disabledforeground
        cursor
        postcommand
        selectcolor      选中时背景
        takefocus
        title       
        type
        relief
       
    方法:
        menu.add_cascade      添加子选项
        menu.add_command      添加命令(label参数为显示内容)
        menu.add_separator    添加分隔线
        menu.add_checkbutton  添加确认按钮
        delete                删除
    菜单Menu的参数和方法

    9、Frame框架

     1 # -*- coding: utf-8 -*-
     2 # @Time    : 2018/4/1 20:11
     3 # @Author  : TanRong
     4 # @Software: PyCharm
     5 # @File    : frame.py
     6 import tkinter as tk
     7 
     8 root = tk.Tk()
     9 root.title("Frame")
    10 root.geometry('400x300')
    11 
    12 tk.Label(root, text='on the window').pack()
    13 frm = tk.Frame(root)
    14 frm.pack()
    15 frm_l = tk.Frame(frm)
    16 frm_r = tk.Frame(frm)
    17 frm_l.pack(side='left') #固定到左侧(是针对父级的,不是主窗口)
    18 frm_r.pack(side='right')
    19 
    20 tk.Label(frm_l, text='on the frm_11').pack()
    21 tk.Label(frm_l, text='on the frm_12').pack()
    22 tk.Label(frm_r, text='on the frm_r').pack()
    23 
    24 root.mainloop()
    View Code

    10、messagebox弹窗

     1 # -*- coding: utf-8 -*-
     2 # @Time    : 2018/4/1 20:19
     3 # @Author  : TanRong
     4 # @Software: PyCharm
     5 # @File    : messagebox.py
     6 import tkinter as tk
     7 import tkinter.messagebox # messagebox必须加这行
     8 
     9 root = tk.Tk()
    10 root.title("messagebox")
    11 root.geometry('400x300')
    12 
    13 def hit_me():
    14     # tk.messagebox.showinfo(title='Hi', message='hahahha')
    15     # tk.messagebox.showwarning(title='Warning', message='nononon')
    16     # tk.messagebox.showerror(title='Error', message='fatal! never!!')
    17     # print(tk.messagebox.askquestion(title='Hi', message='nononon')) #return 'yes' / 'no'
    18     # print(tk.messagebox.askyesno(title='Hi', message='nononon')) # return True / False
    19     # print(tk.messagebox.askretrycancel(title='Hi', message='nononon'))  # return True / False
    20     print(tk.messagebox.askokcancel(title='Hi', message='nononon'))  # return True / False
    21 
    22 tk.Button(root, text='hit me', command=hit_me).pack()
    23 
    24 root.mainloop()
    View Code
    messagebox._show函数的控制参数:
        default         指定消息框按钮;
        icon            指定消息框图标;
        message        指定消息框所显示的消息;
        parent          指定消息框的父组件;
        title           标题;
        type            类型;
    
    simpledialog模块参数:
        title           指定对话框的标题;
        prompt         显示的文字;
        initialvalue    指定输入框的初始值;
    
      filedialog    模块参数:
        filetype       指定文件类型;
        initialdir     指定默认目录;
        initialfile    指定默认文件;
        title         指定对话框标题
    
    colorchooser模块参数:
        initialcolor    指定初始化颜色;
        title           指定对话框标题;
    弹窗参数

    11、pack & gird & place几何管理

     1 # -*- coding: utf-8 -*-
     2 # @Time    : 2018/4/2 0:50
     3 # @Author  : TanRong
     4 # @Software: PyCharm
     5 # @File    : pack_grid_place.py
     6 import tkinter as tk
     7 
     8 root = tk.Tk()
     9 root.title("pack & grid & place")
    10 root.geometry('400x300')
    11 
    12 # tk.Label(root, text=1).pack(side='top')
    13 # tk.Label(root, text=2).pack(side='bottom')
    14 # tk.Label(root, text=3).pack(side='left')
    15 # tk.Label(root, text=4).pack(side='right')
    16 
    17 # for i in range(4):
    18 #     for j in range(3):
    19 #         tk.Label(root, text=1).grid(row=i, column=j, ipadx=10, ipady=10) #padx和pady是外部的x和y方向的扩展长度,ipadx和ipady是内部的
    20 
    21 tk.Label(root, text=1).place(x=10, y=100, anchor='nw')
    22 
    23 root.mainloop()
    View Code

    12、事件关联

    bind(sequence,func,add)——
    bind_class(className,sequence,func,add)
    bind_all(sequence,func,add)
    事件参数:  
    sequence              所绑定的事件;
    func                   所绑定的事件处理函数;
    add                    可选参数,为空字符或‘+’;
    className             所绑定的类;
    
    鼠标键盘事件
        <Button-1>            鼠标左键按下,2表示中键,3表示右键;
        <ButtonPress-1>        同上;
        <ButtonRelease-1>    鼠标左键释放;
        <B1-Motion>           按住鼠标左键移动;
        <Double-Button-1>     双击左键;
        <Enter>               鼠标指针进入某一组件区域;
        <Leave>               鼠标指针离开某一组件区域;
        <MouseWheel>         滚动滚轮;
        <KeyPress-A>         按下A键,A可用其他键替代;
        <Alt-KeyPress-A>      同时按下alt和A;alt可用ctrl和shift替代;
        <Double-KeyPress-A>    快速按两下A;
        <Lock-KeyPress-A>     大写状态下按A;
       
    窗口事件
        Activate             当组件由不可用转为可用时触发;
        Configure            当组件大小改变时触发;
        Deactivate          当组件由可用转变为不可用时触发;
        Destroy              当组件被销毁时触发;
        Expose              当组件从被遮挡状态中暴露出来时触发;
        Unmap              当组件由显示状态变为隐藏状态时触发;
        Map                  当组件由隐藏状态变为显示状态时触发;
        FocusIn              当组件获得焦点时触发;
        FocusOut            当组件失去焦点时触发;
        Property             当窗体的属性被删除或改变时触发;
        Visibility           当组件变为可视状态时触发;
    
    响应事件
    event对象(def function(event)):
        char                按键字符,仅对键盘事件有效;
        keycode            按键名,仅对键盘事件有效;
        keysym             按键编码,仅对键盘事件有效;
        num                鼠标按键,仅对鼠标事件有效;
        type                 所触发的事件类型;
        widget               引起事件的组件;
        width,heigh        组件改变后的大小,仅Configure有效;
        x,y                鼠标当前位置,相对于窗口;
        x_root,y_root       鼠标当前位置,相对于整个屏幕
    View Code

    13、字体

    一般格式:
    ('Times -10 bold')
    ('Times',10,'bold','italic')    依次表示字体、字号、加粗、倾斜
    
    
    补充:
    config            重新配置
    label.config(font='Arial -%d bold' % scale.get())
    依次为字体,大小(大小可为字号大小),加粗
    tkinter.StringVar    能自动刷新的字符串变量,可用set和get方法进行传值和取值,类似的还有IntVar,DoubleVar...
    
     
    View Code

    14、下拉列表Comobobox

    import tkinter as tk
    from tkinter import ttk   #必须加这个
    
    
    def select_algorithm(*args):
        global  algo_selected
        algo_selected = algorithm_combobox.get()
        print(algo_selected)
    
    
    
    algo_name = tk.StringVar()
    algorithm_combobox = ttk.Combobox(tools_frm, textvariable=algo_name, width=12)
    algorithm_combobox['value'] = ('选择算法', 'Classification', 'Clustering', 'Regression', 'Projections', 'Dynamical', 'Optimization') #'Reinforcenment Learning'
    algorithm_combobox['state'] = 'readonly'
    algorithm_combobox.current(0)
    algorithm_combobox.bind("<<ComboboxSelected>>", select_algorithm)  #添加选择事件
    algorithm_combobox.grid(row=1, column=4)
    View Code

    15、文件选择框filedialog

    import tkinter as tk
    import tkinter.filedialog   #必须加
    
    filename = tk.filedialog.askopenfilename(title='选择训练数据', filetypes=[('csv','*.csv')])
        # print(filename)
        if len(filename) != 0:
            data = np.loadtxt(filename, delimiter=',')  # 训练数据
    View Code

    代码实战 - 登录窗口

      1 # -*- coding: utf-8 -*-
      2 # @Time    : 2018/4/2 1:00
      3 # @Author  : TanRong
      4 # @Software: PyCharm
      5 # @File    : login.py
      6 import tkinter as tk
      7 import pickle
      8 import tkinter.messagebox
      9 
     10 root = tk.Tk()
     11 root.title('Welcome to Login')
     12 root.geometry('450x300')
     13 
     14 # welcome image
     15 canvas = tk.Canvas(root, height=200, width=500)
     16 image_file = tk.PhotoImage(file='../images/welcome.gif')
     17 image = canvas.create_image(0,0, anchor='nw', image=image_file)
     18 canvas.pack(side='top')
     19 
     20 #输入框
     21 tk.Label(root, text='User name:').place(x=50, y=150)
     22 tk.Label(root, text='Password:').place(x=50, y=190)
     23 
     24 var_usr_name = tk.StringVar()
     25 var_usr_pwd = tk.StringVar()
     26 var_usr_name.set('loginPython@163.com')
     27 
     28 entry_usr_name = tk.Entry(root, textvariable=var_usr_name)
     29 entry_usr_name.place(x=160, y=150)
     30 entry_usr_pwd = tk.Entry(root, textvariable=var_usr_pwd, show='*')
     31 entry_usr_pwd.place(x=160, y=190)
     32 
     33 def usr_login():
     34     usr_name = var_usr_name.get()
     35     usr_pwd = var_usr_pwd.get()
     36     try:
     37         with open('usrs_info.pickle', 'rb') as usr_file:
     38             usrs_info = pickle.load(usr_file)
     39     except FileNotFoundError:
     40         with open('usrs_info.pickle', 'wb') as usr_file:
     41             usrs_info = {'admin':'admin'} #设置管理员信息
     42             pickle.dump(usrs_info, usr_file)
     43 
     44     if usr_name in usrs_info:
     45         if usr_pwd == usrs_info[usr_name]:
     46             tk.messagebox.showinfo(title='Welcome', message='How are you? '+ usr_name)
     47         else:
     48             tk.messagebox.showerror(title='Error', message='Error your password is wrong, try agein.')
     49     else:
     50         is_sign_up = tk.messagebox.askyesno(title='Welcome',
     51                                             message='You have not sign up. Sign up today?')
     52         if is_sign_up:
     53             usr_sign_up()
     54 def usr_sign_up():
     55     def sign_to_python():
     56         nname = new_name.get()
     57         npwd = new_pwd.get()
     58         npwd_confirm = new_pwd_confirm.get()
     59         with open('usrs_info.pickle', 'rb') as usr_file:
     60             exist_usr_info = pickle.load(usr_file)
     61         if npwd != npwd_confirm:
     62             tk.messagebox.showerror(title='Error', message='Password and Confirm Password must be same!')
     63         elif nname in exist_usr_info:
     64             tk.messagebox.showerror(title='Error', message='The user has already signed up!')
     65         else:
     66             exist_usr_info[nname] = npwd
     67             with open('usrs_info.pickle', 'wb') as usr_file:
     68                 pickle.dump(exist_usr_info, usr_file)
     69             tk.messagebox.showinfo(title='Welcome', message='You have successfully signed up!')
     70             # global var_usr_name  无效
     71             # global var_usr_pwd
     72             # var_usr_name = nname
     73             # var_usr_pwd  = ''
     74             window_sign_up.destroy()
     75 
     76     window_sign_up = tk.Toplevel(root)
     77     window_sign_up.geometry('350x200')
     78     window_sign_up.title('Sign up window')
     79 
     80     new_name = tk.StringVar()
     81     new_name.set('loginPython@163.com')
     82     tk.Label(window_sign_up, text='User name:').place(x=10, y=10)
     83     entry_new_name = tk.Entry(window_sign_up, textvariable=new_name)
     84     entry_new_name.place(x=150, y=10)
     85 
     86     new_pwd = tk.StringVar()
     87     tk.Label(window_sign_up, text='Password:').place(x=10, y=50)
     88     entry_new_pwd = tk.Entry(window_sign_up, textvariable=new_pwd)
     89     entry_new_pwd.place(x=150, y=50)
     90 
     91     new_pwd_confirm = tk.StringVar()
     92     tk.Label(window_sign_up, text='Confirm Password:').place(x=10, y=90)
     93     entry_usr_pwd_confirm = tk.Entry(window_sign_up, textvariable=new_pwd_confirm)
     94     entry_usr_pwd_confirm.place(x=150, y=90)
     95 
     96     btn_confirm_sign_up = tk.Button(window_sign_up, text='Sign up', command=sign_to_python)
     97     btn_confirm_sign_up.place(x=150, y=130)
     98 btn_login = tk.Button(root, text='Login', command=usr_login)
     99 btn_login.place(x=170, y=230)
    100 btn_sign_up = tk.Button(root, text='Sign up', command=usr_sign_up)
    101 btn_sign_up.place(x=270, y=230)
    102 
    103 root.mainloop()
    View Code
    #filename:Caculater
    
    import tkinter,time,decimal,math,string
    
    root=tkinter.Tk()
    root.title('计算器')
    root.resizable(0,0)
    global cuncu, vartext, result, fuhao
    result = fuhao = None
    vartext = tkinter.StringVar()
    cuncu = []
    
    class anjianzhi:
        global cuncu, vartext, result, fuhao
        def __init__(self,anjian):
            self.anjian = anjian
        def jia(self):
            cuncu.append(self.anjian)
            vartext.set( ''.join(cuncu))
        def tui(self):
            cuncu.pop()
            vartext.set(''.join(cuncu))
        def clear(self):
            cuncu.clear()
            vartext.set('')
            result = None
            fuhao = None
        def zhengfu(self):
            if cuncu[0]:
                if cuncu[0] == '-':
                    cuncu[0] = '+'
                elif cuncu[0] == '+':
                    cuncu[0] = '-'
                else:
                    cuncu.insert(0, '-')
            vartext.set(''.join(cuncu))
        def xiaoshudian(self):
            if cuncu.count('.') >= 1:
                pass
            else:
                if cuncu == [] :
                    cuncu.append('0')
                cuncu.append('.')
                vartext.set(''.join(cuncu))
        def yunshuan(self):
            global cuncu, vartext, result, fuhao
            if vartext.get() == '':
                pass
            else:
                get1 = decimal.Decimal(vartext.get())
                if self.anjian in ('1/x','sqrt'):
                    if self.anjian == '1/x':
                        result = 1/get1
                    elif self.anjian == 'sqrt':
                        result = math.sqrt(get1)
                elif  self.anjian in ('+','-','*','/','='):
                    if fuhao is not None:
                        get1 = decimal.Decimal(result)
                        get2 = decimal.Decimal(vartext.get())
                        if fuhao == '+':
                            result = get1 + get2
                        elif fuhao == '-':
                            result = get1 - get2
                        elif fuhao == '*':
                            result = get1 * get2
                        elif fuhao == '/':
                            result = get1 / get2
                    else:
                        result = get1
                    if self.anjian == '=':
                        fuhao = None
                    else:
                        fuhao = self.anjian
                print(fuhao)
                print(result)
                vartext.set(str(result))
                cuncu.clear()
    
    def copy1():
        # tkinter.Misc().clipboard_clear()
        tkinter.Misc().clipboard_append(string(vartext.get()))
    
    def buju(root):
        global cuncu, vartext, result, fuhao
        entry1 = tkinter.Label(root, width=30, height=2, bg='white', anchor='se', textvariable=vartext)
        entry1.grid(row=0, columnspan=5)
        buttonMC=tkinter.Button(root,text='MC',width=5)
        buttonMR=tkinter.Button(root,text='MR',width=5)
        buttonMS=tkinter.Button(root,text='MS',width=5)
        buttonM1=tkinter.Button(root,text='M+',width=5)
        buttonM2=tkinter.Button(root,text='M-',width=5)
        buttonMC.grid(row=1,column=0)
        buttonMR.grid(row=1,column=1)
        buttonMS.grid(row=1,column=2)
        buttonM1.grid(row=1,column=3)
        buttonM2.grid(row=1,column=4)
    
    
        buttonJ=tkinter.Button(root,text='',width=5,command=anjianzhi('c').tui)
        buttonCE=tkinter.Button(root,text='CE',width=5)
        buttonC=tkinter.Button(root,text=' C ',width=5,command=anjianzhi('c').clear)
        button12=tkinter.Button(root,text='±',width=5,command=anjianzhi('c').zhengfu)
        buttonD=tkinter.Button(root,text='',width=5,command=anjianzhi('sqrt').yunshuan)
        buttonJ.grid(row=2,column=0)
        buttonCE.grid(row=2,column=1)
        buttonC.grid(row=2,column=2)
        button12.grid(row=2,column=3)
        buttonD.grid(row=2,column=4)
    
        button7=tkinter.Button(root,text=' 7 ',width=5,command=anjianzhi('7').jia)
        button8=tkinter.Button(root,text=' 8 ',width=5,command=anjianzhi('8').jia)
        button9=tkinter.Button(root,text=' 9 ',width=5,command=anjianzhi('9').jia)
        buttonc=tkinter.Button(root, text=' / ',width=5,command=anjianzhi('/').yunshuan)
        buttonf= tkinter.Button(root, text=' % ',width=5)
        button7.grid(row=3,column=0)
        button8.grid(row=3,column=1)
        button9.grid(row=3,column=2)
        buttonc.grid(row=3,column=3)
        buttonf.grid(row=3,column=4)
    
        button4=tkinter.Button(root,text=' 4 ',width=5,command=anjianzhi('4').jia)
        button5=tkinter.Button(root,text=' 5 ',width=5,command=anjianzhi('5').jia)
        button6=tkinter.Button(root,text=' 6 ',width=5,command=anjianzhi('6').jia)
        buttonx=tkinter.Button(root,text=' * ',width=5,command=anjianzhi('*').yunshuan)
        buttonfs=tkinter.Button(root,text='1/x',width=5,command=anjianzhi('1/x').yunshuan)
        button4.grid(row=4,column=0)
        button5.grid(row=4,column=1)
        button6.grid(row=4,column=2)
        buttonx.grid(row=4,column=3)
        buttonfs.grid(row=4,column=4)
    
        button1 = tkinter.Button(root, text=' 1 ',width=5,command=anjianzhi('1').jia)
        button2 = tkinter.Button(root, text=' 2 ',width=5,command=anjianzhi('2').jia)
        button3 = tkinter.Button(root, text=' 3 ',width=5,command=anjianzhi('3').jia)
        button_= tkinter.Button(root, text=' - ',width=5,command=anjianzhi('-').yunshuan)
        buttondy= tkinter.Button(root, text=' 
     = 
     ',width=5,command=anjianzhi('=').yunshuan)
        button1.grid(row=5, column=0)
        button2.grid(row=5, column=1)
        button3.grid(row=5, column=2)
        button_.grid(row=5, column=3)
        buttondy.grid(row=5, column=4,rowspan=2)
    
        button0=tkinter.Button(root,text='   0   ',width=11,command=anjianzhi('0').jia)
        buttonjh = tkinter.Button(root,text=' . ',width=5,command=anjianzhi('c').xiaoshudian)
        buttonjia=tkinter.Button(root,text=' + ',width=5,command=anjianzhi('+').yunshuan)
        button0.grid(row=6,column=0,columnspan=2)
        buttonjh.grid(row=6,column=2)
        buttonjia.grid(row=6,column=3)
    def caidan(root):
    
        menu=tkinter.Menu(root)
        submenu1=tkinter.Menu(menu,tearoff=0)
        menu.add_cascade(label='查看',menu=submenu1)
        submenu2 = tkinter.Menu(menu, tearoff=0)
        submenu2.add_command(label='复制')
        submenu2.add_command(label='粘贴')
        menu.add_cascade(label='编辑',menu=submenu2)
        submenu = tkinter.Menu(menu, tearoff=0)
        submenu.add_command(label='查看帮助')
        submenu.add_separator()
        submenu.add_command(label='关于计算机')
        menu.add_cascade(label='帮助',menu=submenu)
        root.config(menu=menu)
    
    
    buju(root)
    caidan(root)
    root.mainloop()
    
    计算器
    tkinter 计算器(不是我写的)

    tkinter中的颜色:

     

    参考链接: tkinter模块常用参数(python3)http://www.cnblogs.com/aland-1415/p/6849193.html

  • 相关阅读:
    linux安装jdk(二)
    Java实现进程调度算法(一) FCFS(先来先服务)
    用Java Swing实现Freecell(空当接龙)
    windows主机开启MySQL慢查询日志
    CentOS LNMP 服务器安装配置详解
    shopex 网店系统 v4.8.5 安装图文教
    mysqldumpslow和mysqlsla分析mysql慢查询日志
    window下nginx配置
    PHP开发编码规范
    IIS+PHP+MySQL+Zend Guard Loader(ZendOptimizer)+phpMyAdmin环境配置图解(转)
  • 原文地址:https://www.cnblogs.com/tanrong/p/8666912.html
Copyright © 2020-2023  润新知