Python GUI - tkinter

目录:

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) 有一个控件产生了。

主窗口常用操作:

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

Tkinter 组件

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

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

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

Python GUI - tkinter

标准属性

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

Python GUI - tkinter

几何管理

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

Python GUI - 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之间的小数;
width: 组件的宽度;
heitht:   组件的高度;
relwidth: 组件相对于窗口的宽度,0-1;
relheight:  组件相对于窗口的高度,0-1;

代码实例:

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()
    anchor:            指定按钮上文本的位置;
background(bg)   指定按钮的背景色;
bitmap:      指定按钮上显示的位图;
borderwidth(bd)    指定按钮边框的宽度;
command:       指定按钮消息的回调函数;
cursor:     指定鼠标移动到按钮上的指针样式;
font:    指定按钮上文本的字体;
foreground(fg)     指定按钮的前景色;
height:     指定按钮的高度;
image:      指定按钮上显示的图片;
state:     指定按钮的状态(disabled);
text:     指定按钮上显示的文本;
width:      指定按钮的宽度
padx      设置文本与按钮边框x的距离,还有pady;
activeforeground    按下时前景色
textvariable    可变文本,与StringVar等配合着用

Button按钮的参数

    Anchor            标签中文本的位置;
background(bg)    背景色;
foreground(fg)   前景色;
borderwidth(bd)   边框宽度;
width      标签宽度;
height     标签高度;
bitmap     标签中的位图;
font    字体;
image      标签中的图片;
justify     多行文本的对齐方式;
text        标签中的文本,可以使用'\n'表示换行
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()
    background(bg)      文本框背景色;
foreground(fg) 前景色;
selectbackground   选定文本背景色;
selectforeground   选定文本前景色;
borderwidth(bd)   文本框边框宽度;
font  字体;
show    文本框显示的字符,若为*,表示文本框为密码框;
state    状态;
width      文本框宽度
textvariable    可变文本,与StringVar等配合着用

文本框tkinter.Entry,tkinter.Text控制参数

3、Listbox列表

 # -*- coding: utf-8 -*-
# @Time : 2018/4/1 0:45
# @Author : TanRong
# @Software: PyCharm
# @File : listbox.py from tkinter import * root = Tk();
root.title('Listbox')
root.geometry('400x300') var1 = StringVar()
lable = Label(root, bg='yellow', width=4, textvariable=var1)
lable.pack() def print_selection():
value = lb.get(lb.curselection()) #得到光标选定的列表项
var1.set(value) button = Button(root, text='print selection', width=15, height=2, command=print_selection)
button.pack() var2 = StringVar()
var2.set((11,22,33,55))
lb = Listbox(root, listvariable=var2)
list_items = [1,2,3,4]
for item in list_items:
lb.insert('end', item)
lb.insert(1, 'first') #索引插入,第2位插入first
lb.insert(2, 'second')
lb.delete(2)#索引删除
lb.pack() root.mainloop()

4、Radiobutton单选框

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

单选框Radiobutton控制参数

5、Scale尺度

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

6、Checkbutton复选框

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

复选框Checkbutton控制参数

7、Canvas 画布

 # -*- coding: utf-8 -*-
# @Time : 2018/4/1 16:02
# @Author : TanRong
# @Software: PyCharm
# @File : canvas.py import tkinter as tk root = tk.Tk()
root.title('Canvas')
root.geometry('400x300') canvas = tk.Canvas(root, bg='blue', height=100, width=200)
image_file = tk.PhotoImage(file='../images/23.gif')
image = canvas.create_image(10, 10, anchor='nw', image=image_file) #是图片锚定的点 x0,y0,x1,y1 = 50,50,80,80
line = canvas.create_line(x0,y0,x1,y1) oval = canvas.create_oval(x0,y0,x1,y1,fill='red') #x0,y0,x1,y1是圆的外接正方形
arc = canvas.create_arc(x0+30,y0+30,x1+30,y1+30, start=0, extent=160)#0-160角度范围
rect = canvas.create_rectangle(100,30,100+20,30+20)
canvas.pack() def moveit():
canvas.move(rect, 1, 2) #rect是正方形id,1是x方向移动,2是y方向移动
button = tk.Button(root, text='move', command=moveit).pack() root.mainloop()
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菜单

 # -*- coding: utf-8 -*-
# @Time : 2018/4/1 16:02
# @Author : TanRong
# @Software: PyCharm
# @File : menubar.py
import tkinter as tk root = tk.Tk()
root.title("Menubar")
root.geometry('400x300') label = tk.Label(root, text='', bg='yellow')
label.pack() counter = 0
def do_job():
global counter
label.config(text='do '+ str(counter)) #如果直接将pack()写在label定义的后面,则在这里就会出现label没有config属性的错误
counter += 1
menubar = tk.Menu(root)
filemenu = tk.Menu(menubar, tearoff=0)#tearoff是指不可分割 它的值只有0和1,将tearoff设置为1以后,就是表明这个菜单是可以独立出来的,如果是0的话就不可以独立出来。代码演示一下即可。
menubar.add_cascade(label='File', menu=filemenu)
filemenu.add_command(label='New', command=do_job)
filemenu.add_command(label='Open', command=do_job)
filemenu.add_command(label='Save', command=do_job)
filemenu.add_separator()
filemenu.add_command(label='Exit',command=root.quit) editmenu = tk.Menu(menubar, tearoff=0)
menubar.add_cascade(label='Edit', menu=editmenu)
editmenu.add_command(label='Cut', command=do_job)
editmenu.add_command(label='Copy', command=do_job)
editmenu.add_command(label='Paste', command=do_job) submenu = tk.Menu(filemenu)
filemenu.add_cascade(label='Import', menu=submenu, underline=0)
submenu.add_command(label='Submenu1', command=do_job) root.config(menu = menubar) #将整个menubar添加到窗口
root.mainloop()
参数:
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框架

 # -*- coding: utf-8 -*-
# @Time : 2018/4/1 20:11
# @Author : TanRong
# @Software: PyCharm
# @File : frame.py
import tkinter as tk root = tk.Tk()
root.title("Frame")
root.geometry('400x300') tk.Label(root, text='on the window').pack()
frm = tk.Frame(root)
frm.pack()
frm_l = tk.Frame(frm)
frm_r = tk.Frame(frm)
frm_l.pack(side='left') #固定到左侧(是针对父级的,不是主窗口)
frm_r.pack(side='right') tk.Label(frm_l, text='on the frm_11').pack()
tk.Label(frm_l, text='on the frm_12').pack()
tk.Label(frm_r, text='on the frm_r').pack() root.mainloop()

10、messagebox弹窗

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

弹窗参数

11、pack & gird & place几何管理

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

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       鼠标当前位置,相对于整个屏幕

13、字体

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

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)

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=',') # 训练数据

代码实战 - 登录窗口

 # -*- coding: utf-8 -*-
# @Time : 2018/4/2 1:00
# @Author : TanRong
# @Software: PyCharm
# @File : login.py
import tkinter as tk
import pickle
import tkinter.messagebox root = tk.Tk()
root.title('Welcome to Login')
root.geometry('450x300') # welcome image
canvas = tk.Canvas(root, height=200, width=500)
image_file = tk.PhotoImage(file='../images/welcome.gif')
image = canvas.create_image(0,0, anchor='nw', image=image_file)
canvas.pack(side='top') #输入框
tk.Label(root, text='User name:').place(x=50, y=150)
tk.Label(root, text='Password:').place(x=50, y=190) var_usr_name = tk.StringVar()
var_usr_pwd = tk.StringVar()
var_usr_name.set('loginPython@163.com') entry_usr_name = tk.Entry(root, textvariable=var_usr_name)
entry_usr_name.place(x=160, y=150)
entry_usr_pwd = tk.Entry(root, textvariable=var_usr_pwd, show='*')
entry_usr_pwd.place(x=160, y=190) def usr_login():
usr_name = var_usr_name.get()
usr_pwd = var_usr_pwd.get()
try:
with open('usrs_info.pickle', 'rb') as usr_file:
usrs_info = pickle.load(usr_file)
except FileNotFoundError:
with open('usrs_info.pickle', 'wb') as usr_file:
usrs_info = {'admin':'admin'} #设置管理员信息
pickle.dump(usrs_info, usr_file) if usr_name in usrs_info:
if usr_pwd == usrs_info[usr_name]:
tk.messagebox.showinfo(title='Welcome', message='How are you? '+ usr_name)
else:
tk.messagebox.showerror(title='Error', message='Error your password is wrong, try agein.')
else:
is_sign_up = tk.messagebox.askyesno(title='Welcome',
message='You have not sign up. Sign up today?')
if is_sign_up:
usr_sign_up()
def usr_sign_up():
def sign_to_python():
nname = new_name.get()
npwd = new_pwd.get()
npwd_confirm = new_pwd_confirm.get()
with open('usrs_info.pickle', 'rb') as usr_file:
exist_usr_info = pickle.load(usr_file)
if npwd != npwd_confirm:
tk.messagebox.showerror(title='Error', message='Password and Confirm Password must be same!')
elif nname in exist_usr_info:
tk.messagebox.showerror(title='Error', message='The user has already signed up!')
else:
exist_usr_info[nname] = npwd
with open('usrs_info.pickle', 'wb') as usr_file:
pickle.dump(exist_usr_info, usr_file)
tk.messagebox.showinfo(title='Welcome', message='You have successfully signed up!')
# global var_usr_name 无效
# global var_usr_pwd
# var_usr_name = nname
# var_usr_pwd = ''
window_sign_up.destroy() window_sign_up = tk.Toplevel(root)
window_sign_up.geometry('350x200')
window_sign_up.title('Sign up window') new_name = tk.StringVar()
new_name.set('loginPython@163.com')
tk.Label(window_sign_up, text='User name:').place(x=10, y=10)
entry_new_name = tk.Entry(window_sign_up, textvariable=new_name)
entry_new_name.place(x=150, y=10) new_pwd = tk.StringVar()
tk.Label(window_sign_up, text='Password:').place(x=10, y=50)
entry_new_pwd = tk.Entry(window_sign_up, textvariable=new_pwd)
entry_new_pwd.place(x=150, y=50) new_pwd_confirm = tk.StringVar()
tk.Label(window_sign_up, text='Confirm Password:').place(x=10, y=90)
entry_usr_pwd_confirm = tk.Entry(window_sign_up, textvariable=new_pwd_confirm)
entry_usr_pwd_confirm.place(x=150, y=90) btn_confirm_sign_up = tk.Button(window_sign_up, text='Sign up', command=sign_to_python)
btn_confirm_sign_up.place(x=150, y=130)
btn_login = tk.Button(root, text='Login', command=usr_login)
btn_login.place(x=170, y=230)
btn_sign_up = tk.Button(root, text='Sign up', command=usr_sign_up)
btn_sign_up.place(x=270, y=230) root.mainloop()
#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 *(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('')
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').*)
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('').jia)
button8=tkinter.Button(root,text=' 8 ',width=5,command=anjianzhi('').jia)
button9=tkinter.Button(root,text=' 9 ',width=5,command=anjianzhi('').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('').jia)
button5=tkinter.Button(root,text=' 5 ',width=5,command=anjianzhi('').jia)
button6=tkinter.Button(root,text=' 6 ',width=5,command=anjianzhi('').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('').jia)
button2 = tkinter.Button(root, text=' 2 ',width=5,command=anjianzhi('').jia)
button3 = tkinter.Button(root, text=' 3 ',width=5,command=anjianzhi('').jia)
button_= tkinter.Button(root, text=' - ',width=5,command=anjianzhi('-').yunshuan)
buttondy= tkinter.Button(root, text=' \n = \n ',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('').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中的颜色:

Python GUI - tkinter

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

上一篇:ubuntu 12.10上安装tftpd-hpa


下一篇:在 Ubuntu 12.04 上安装 GitLab7.x