[PYTHON] 核心编程笔记(19.图形用户界面编程)

本文涉及的产品
网络型负载均衡 NLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
传统型负载均衡 CLB,每月750个小时 15LCU
简介:

19.1 简介


19.1.1 什么是Tcl,Tk和Tkinter?


19.1.2 安装和使用Tkinter


# apt-get install python-tk -y


# python

-------------------------------

Python 2.7.3 (default, Sep 26 2012, 21:51:14)

[GCC 4.7.2] on linux2

Type "help", "copyright", "credits" or "license" for more information.

>>> import Tkinter

>>>

--------------------------------


19.2 Tkinter与Python编程


19.2.1 Tkinter模块:把Tk引入您的程序

1.导入Tkinter模块(import Tkinter,或者,from Tkinter import *)

2.创建一个顶层窗口对象,来容纳您的整个GUI程序

3.在您顶层窗口对象上或其中创建所有的GUI模块(以及功能)

4.把这些GUI模块与地层程序代码相连接

5.进入主事件循环


第一步很明显,所有使用Tkinter的GUI程序必须先导入Tkinter模块,第一步就是为


了获得Tkinter的访问权


19.2.2 GUI程序开发简介


19.2.3 顶层窗口:Tkinter.Tk()


>>> import Tkinter

>>> top = Tkinter.Tk()


19.2.4 Tk组件


例,标签组件演示(tkhello1.py)

# vi tkhello1.py

----------------------------

#!/usr/bin/env python


import Tkinter


top = Tkinter.Tk()

label = Tkinter.Label(top, text = 'Hello World!')

label.pack()

Tkinter.mainloop()

----------------------------


19.3 Tkiner 举例


19.3.1 标签组件


19.3.2 按钮组件


例,按钮组件演示

# vi tkhello2.py

------------------------------

#!/usr/bin/env python


import Tkinter


top = Tkinter.Tk()

quit = Tkinter.Button(top, text = 'Hello World!', command = top.quit)

quit.pack()

Tkinter.mainloop()

------------------------------


19.3.3 标签和按钮组件


例,标签和按钮组件演示

# vi tkhello3.py

------------------------------

#!/usr/bin/env python


import Tkinter


top = Tkinter.Tk()

hello = Tkinter.Label(top, text='Hello World!')

hello.pack()


quit = Tkinter.Button(top, text='QUIT',

     command=top.quit, bg='red',fg='white')

quit.pack(fill=Tkinter.X, expand=1)

Tkinter.mainloop()

------------------------------


19.3.4 标签,按钮和进度条组件


例,标签,按钮和进度条组件演示


我们最后一个组件例子介绍进度条组件,重点放在组件间通过回调函数的交互[诸


如resize()],您对进度条组件的动作将影响标签组件上的文字


# vi tkhello4.py

------------------------------------

#!/usr/bin/env python


from Tkinter import *


def resize(ev=None):

   label.config(font='Helvetica -%d bold' % \

       scale.get())


top = Tk()

top.geometry('250x150')


label = Label(top, text='Hello World!',

   font='Helvetica -12 bold')

label.pack(fill=Y, expand=1)


scale = Scale(top, from_=10, to=40,

   orient=HORIZONTAL, command=resize)

scale.set(12)

scale.pack(fill=X, expand=1)


quit = Button(top, text='QUIT',

   command=top.quit, activeforeground='white',

   activebackground='red')

quit.pack()


mainloop()


------------------------------------


19.3.5 偏函数应用举例


例,运用PFA的路灯指示牌GUI程序

# vi pfaGUI2.py

--------------------------------------

#!/usr/bin/env python


from functools import partial as pto

from Tkinter import Tk, Button, X

from tkMessageBox import showinfo, showwarning, showerror


WARN = 'warn'

CRIT = 'crit'

REGU = 'regu'


SIGNS = {

   'do not enter': CRIT,

   'railroad crossing': WARN,

   '55\nspeed limit': REGU,

   'wrong way': CRIT,

   'merging traffic': WARN,

   'one way': REGU,

}


critCB = lambda : showerror('Error', 'Error Button Pressed!')

warnCB = lambda : showwarning('Warning',

   'Warning Button Pressed!')

infoCB = lambda : showinfo('Info', 'Info Button Pressed!')


top = Tk()  

top.title('Road Signs')

Button(top, text='QUIT', command=top.quit,

   bg='red', fg='white').pack()


MyButton = pto(Button, top)

CritButton = pto(MyButton, command=critCB, bg='white', fg='red')

WarnButton = pto(MyButton, command=warnCB, bg='goldenrod1')

ReguButton = pto(MyButton, command=infoCB, bg='white')


for eachSign in SIGNS:

   signType = SIGNS[eachSign]

   cmd = '%sButton(text=%r%s).pack(fill=X, expand=True)' % (

       signType.title(), eachSign,

       '.upper()' if signType == CRIT else '.title()')

   eval(cmd)


top.mainloop()

--------------------------------------


19.3.6 中级Tkinter范例


例,文件遍历系统(listdir.py)


这个稍高级一些的GUI程序扩大的组件的使用范围,演员名单新增了列表框,文本框


,和滚动条,而且还有大量的回调函数,例如鼠标点击,键盘输入,和滚动条操作


# vi listdir.py

----------------------------------------

#!/usr/bin/env python


import os

from time import sleep

from Tkinter import *


class DirList:


   def __init__(self, initdir=None):

       self.top = Tk()

       self.label = Label(self.top, \

           text='Directory Lister' + ' v1.1')

       self.label.pack()


       self.cwd=StringVar(self.top)


       self.dirl = Label(self.top, fg='blue',

           font=('Helvetica', 12, 'bold'))

       self.dirl.pack()


       self.dirfm = Frame(self.top)

       self.dirsb = Scrollbar(self.dirfm)

       self.dirsb.pack(side=RIGHT, fill=Y)

       self.dirs = Listbox(self.dirfm, height=15, \

           width=50, yscrollcommand=self.dirsb.set)

       self.dirs.bind('<Double-1>', self.setdirandgo)

       self.dirsb.config(command=self.dirs.yview)

       self.dirs.pack(side=LEFT, fill=BOTH)

       self.dirfm.pack()


       self.dirn = Entry(self.top, width=50, \

           textvariable=self.cwd)

       self.dirn.bind('<Return>', self.dols)

       self.dirn.pack()


       self.bfm = Frame(self.top)

       self.clr = Button(self.bfm, text='Clear', \

           command=self.clrdir, \

           activeforeground='white', \

           activebackground='blue')

       self.ls = Button(self.bfm, \

           text='List Directory', \

           command=self.dols, \

           activeforeground='white', \

           activebackground='green')

       self.quit = Button(self.bfm, text='Quit', \

           command=self.top.quit, \

           activeforeground='white', \

           activebackground='red')

       self.clr.pack(side=LEFT)

       self.ls.pack(side=LEFT)

       self.quit.pack(side=LEFT)

       self.bfm.pack()


       if initdir:

           self.cwd.set(os.curdir)

           self.dols()


   def clrdir(self, ev=None):

       self.cwd.set('')


   def setdirandgo(self, ev=None):

       self.last = self.cwd.get()

       self.dirs.config(selectbackground='red')

       check = self.dirs.get(self.dirs.curselection())

       if not check:

           check = os.curdir

       self.cwd.set(check)

       self.dols()


   def dols(self, ev=None):

       error = ''

       tdir = self.cwd.get()

       if not tdir: tdir = os.curdir


       if not os.path.exists(tdir):

           error = tdir + ': no such file'

       elif not os.path.isdir(tdir):

           error = tdir + ': not a directory'


       if error:

           self.cwd.set(error)

           self.top.update()

           sleep(2)

           if not (hasattr(self, 'last') \

and self.last):

   self.last = os.curdir

           self.cwd.set(self.last)

           self.dirs.config( \

selectbackground='LightSkyBlue')

           self.top.update()

           return


       self.cwd.set( \

   'FETCHING DIRECTORY CONTENTS...')

       self.top.update()

       dirlist = os.listdir(tdir)

       dirlist.sort()

       os.chdir(tdir)

       self.dirl.config(text=os.getcwd())

       self.dirs.delete(0, END)

       self.dirs.insert(END, os.curdir)

       self.dirs.insert(END, os.pardir)

       for eachFile in dirlist:

           self.dirs.insert(END, eachFile)

       self.cwd.set(os.curdir)

       self.dirs.config( \

   selectbackground='LightSkyBlue')


def main():

   d = DirList(os.curdir)

   mainloop()


if __name__ == '__main__':

   main()

----------------------------------------


19.4 其他GUI简介


19.4.1 Tk interface eXtensions(Tix)


# apt-get install tix -y

# vi animalTix.pyw

-------------------------------------------

#!/usr/bin/env python


from Tkinter import Label, Button, END

from Tix import Tk, Control, ComboBox


top = Tk()

top.tk.eval('package require Tix')


lb = Label(top,

   text='Animals (in pairs; min: pair, max: dozen)')

lb.pack()


ct = Control(top, label='Number:',

   integer=True, max=12, min=2, value=2, step=2)

ct.label.config(font='Helvetica -14 bold')

ct.pack()


cb = ComboBox(top, label='Type:', editable=True)

for animal in ('dog', 'cat', 'hamster', 'python'):

   cb.insert(END, animal)

cb.pack()


qb = Button(top, text='QUIT',

   command=top.quit, bg='red', fg='white')

qb.pack()


top.mainloop()


-------------------------------------------


19.4.2 Python MegaWidgets(PMW)


19.4.3 wxWidgets和wxPython


Pmw GUI程序演示

# apt-get install python-pmw -y

# vi animalPmw.pyw

----------------------------------

#!/usr/bin/env python


from Tkinter import Button, END, Label, W

from Pmw import initialise, ComboBox, Counter


top = initialise()


lb = Label(top,

   text='Animals (in pairs; min: pair, max: dozen)')

lb.pack()


ct = Counter(top, labelpos=W, label_text='Number:',

   datatype='integer', entryfield_value=2,

   increment=2, entryfield_validate={'validator':

   'integer', 'min': 2, 'max': 12})

ct.pack()


cb = ComboBox(top, labelpos=W, label_text='Type:')

for animal in ('dog', 'cat', 'hamster', 'python'):

   cb.insert(END, animal)

cb.pack()


qb = Button(top, text='QUIT',

   command=top.quit, bg='red', fg='white')

qb.pack()


top.mainloop()


----------------------------------


wxPython GUI程序演示


# vi animalWx.pyw

-----------------------------------

#!/usr/bin/env python


from Tkinter import Button, END, Label, W

from Pmw import initialise, ComboBox, Counter


top = initialise()


lb = Label(top,

   text='Animals (in pairs; min: pair, max: dozen)')

lb.pack()


ct = Counter(top, labelpos=W, label_text='Number:',

   datatype='integer', entryfield_value=2,

   increment=2, entryfield_validate={'validator':

   'integer', 'min': 2, 'max': 12})

ct.pack()


cb = ComboBox(top, labelpos=W, label_text='Type:')

for animal in ('dog', 'cat', 'hamster', 'python'):

   cb.insert(END, animal)

cb.pack()


qb = Button(top, text='QUIT',

   command=top.quit, bg='red', fg='white')

qb.pack()


top.mainloop()


-----------------------------------


19.4.4 GTK+ 和 PyGTK


PyGTk GUI 程序演示(animalGtk.pyw)

# vi animalGtk.pyw

--------------------------------------

#!/usr/bin/env python


import pygtk

pygtk.require('2.0')

import gtk

import pango


class GTKapp(object):

   def __init__(self):

   top = gtk.Window(gtk.WINDOW_TOPLEVEL)

   top.connect("delete_event", gtk.main_quit)

   top.connect("destroy", gtk.main_quit)

   box = gtk.VBox(False, 0)

   lb = gtk.Label(

       'Animals (in pairs; min: pair, max: dozen)')

   box.pack_start(lb)


   sb = gtk.HBox(False, 0)

   adj = gtk.Adjustment(2, 2, 12, 2, 4, 0)

   sl = gtk.Label('Number:')

   sl.modify_font(

       pango.FontDescription("Arial Bold 10"))

   sb.pack_start(sl)

   ct = gtk.SpinButton(adj, 0, 0)

   sb.pack_start(ct)

   box.pack_start(sb)


   cb = gtk.HBox(False, 0)

   c2 = gtk.Label('Type:')

   cb.pack_start(c2)

   ce = gtk.combo_box_entry_new_text()

   for animal in ('dog', 'cat', 'hamster', 'python'):

       ce.append_text(animal)

   cb.pack_start(ce)

   box.pack_start(cb)


   qb = gtk.Button("")

   red = gtk.gdk.color_parse('red')

   sty = qb.get_style()

   for st in (gtk.STATE_NORMAL,

       gtk.STATE_PRELIGHT, gtk.STATE_ACTIVE):

       sty.bg[st] = red

   qb.set_style(sty)

   ql = qb.child

   ql.set_markup('<span color="white">QUIT</span>')

   qb.connect_object("clicked",

       gtk.Widget.destroy, top)

   box.pack_start(qb)

   top.add(box)

   top.show_all()


if __name__ == '__main__':

   animal = GTKapp()

   gtk.main()


--------------------------------------


19.5 相关模块和其他GUI

GUI 模块或系统描述

TkinterTK INTERface:     Python的默认GUI工具集

PmwPython                MegaWidgets(Tkinter扩展)

TixTk                    Interface eXtension(Tk 扩展)

TkZinc(Zinc)             Extended Tk Canvas type(Tk 扩展)

EasyGUI(easygui)         非常简单的非事件驱动GUI(Tk 扩展)

TIDE+(IDE Studio)        Tix集成开发环境


wxWidgets相关模块

wxPython                Python对wxWidgets的绑定,一个跨平台的GUI框架库(早期称为wxWindows)

Boa                     ConstructorPython集成开发环境兼wxPython GUI构造工具

PythonCard              基于wxPython的GUI桌面应用程序工具集

wxGlade                 另一个wxPython GUI设计工具


商业软件

win32ui                Python版的Microsoft MFC

swing                  Python版的Sun Microsystems Java/swing(基于Jython)







     本文转自 showerlee 51CTO博客,原文链接:http://blog.51cto.com/showerlee/1347183,如需转载请自行联系原作者

相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
1月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
1月前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
116 80
|
24天前
|
Python
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
40 14
|
1月前
|
分布式计算 大数据 数据处理
技术评测:MaxCompute MaxFrame——阿里云自研分布式计算框架的Python编程接口
随着大数据和人工智能技术的发展,数据处理的需求日益增长。阿里云推出的MaxCompute MaxFrame(简称“MaxFrame”)是一个专为Python开发者设计的分布式计算框架,它不仅支持Python编程接口,还能直接利用MaxCompute的云原生大数据计算资源和服务。本文将通过一系列最佳实践测评,探讨MaxFrame在分布式Pandas处理以及大语言模型数据处理场景中的表现,并分析其在实际工作中的应用潜力。
83 2
|
7月前
|
Python
Python基础教程(第3版)中文版 第12章 图形用户界面 (笔记)
Python基础教程(第3版)中文版 第12章 图形用户界面 (笔记)
|
6月前
|
Python
在Python中,`tkinter`是一个用于创建图形用户界面(GUI)的标准库。
在Python中,`tkinter`是一个用于创建图形用户界面(GUI)的标准库。
|
8月前
|
Python 容器
Python与GUI编程:创建图形用户界面
Python的Tkinter库是用于构建GUI应用的内置工具,无需额外安装。它提供了丰富的控件,如按钮、文本框等,让用户通过图形界面与程序交互。创建GUI窗口的基本步骤包括:导入Tkinter库,创建窗口对象,设置窗口属性,添加控件(如标签和按钮),并使用布局管理器(如`pack()`或`grid()`)来组织控件的位置。此外,可以通过绑定事件处理函数来响应用户操作,例如点击按钮。Tkinter还有更多高级功能,适合开发复杂GUI应用。
|
7月前
|
计算机视觉 索引 Python
openCV 3计算机视觉 Python语言实现 笔记__第二章 处理文件、摄像头和图形用户界面
openCV 3计算机视觉 Python语言实现 笔记__第二章 处理文件、摄像头和图形用户界面
|
8月前
|
开发框架 程序员 开发者
Python GUI编程:从入门到精通3.2 GUI编程:学习使用Tkinter、PyQt或wxPython等库创建图形用户界面。
Python GUI编程:从入门到精通3.2 GUI编程:学习使用Tkinter、PyQt或wxPython等库创建图形用户界面。
145 1
|
8月前
|
API 开发工具 C++
Python图形用户界面(GUI)编程:大解密
Python图形用户界面(GUI)编程:大解密
432 0