Python GUI Tkinter学习笔记
Part One:
回顾一下上面的第一篇学习笔记,并给出相应的demo:
import tkinter as tk
from tkinter import ttk
win = tk.Tk()
win.title("Python GUI Notes")
# Disable resizeing the GUI by passing in False/False
# win.resizable(False,False)
# Button Click Event Function
def click_me():
btn.configure(text="** I have been Clicked!**")
label.configure(foreground='red')
label.configure(text='A Red Label')
# Adding a Label
label = ttk.Label(win,text="A test Label")
label.grid(row=0,column=0)
# Adding a Button
btn = ttk.Button(win,text="Click me!",command=click_me)
btn.grid(row=0,column=1)
# Start the GUI
win.mainloop()
界面想过如下:
点击后的界面:
接下来我们创建一个文本框组件,相应的代码如下:
import tkinter as tk
from tkinter import ttk
win = tk.Tk()
win.title("Python GUI Notes")
# Disable resizeing the GUI by passing in False/False
# win.resizable(False,False)
def click_me():
btn.configure(text='Hello '+ name.get())
ttk.Label(win,text="Enter a name:").grid(row=0,column=0)
# Adding a Text box Entry widget
name = tk.StringVar()
name_entered = ttk.Entry(win,width=12,textvariable=name)
name_entered.grid(row=1,column=0)
# name_entered.focus()
btn = ttk.Button(win,text="Click me!",command=click_me)
btn.grid(row=1,column=1)
# Start the GUI
win.mainloop()
实现的效果图如下:
输入姓名后,点击后的效果图:
下面我们创建一个下拉列表框组件,相应代码如下:
import tkinter as tk
from tkinter import ttk
win = tk.Tk()
win.title("Python GUI Notes")
# Disable resizeing the GUI by passing in False/False
# win.resizable(False,False)
def click_me():
btn.configure(text='Hello '+ name.get()+' '+number_chose.get())
label1=ttk.Label(win,text="Enter a name:").grid(row=0,column=0)
label2=ttk.Label(win,text="Choose a number:").grid(row=0,column=1)
# Adding a Text box Entry widget
name = tk.StringVar()
name_entered = ttk.Entry(win,width=12,textvariable=name)
name_entered.grid(row=1,column=0)
number = tk.StringVar()
number_chose = ttk.Combobox(win,width=12,textvariable=number)
number_chose['values'] = (1,2,4,42,56,100)
number_chose.grid(row=1,column=1)
number_chose.current(0)
# name_entered.focus()
btn = ttk.Button(win,text="Click me!",command=click_me)
btn.grid(row=1,column=2)
# Start the GUI
win.mainloop()
代码运行后的效果:
代码点击后的效果:
下面在上面基础上添加判断框组件,相应代码如下:
import tkinter as tk
from tkinter import ttk
win = tk.Tk()
win.title("Python GUI Notes")
# Disable resizeing the GUI by passing in False/False
# win.resizable(False,False)
def click_me():
btn.configure(text='Hello '+ name.get()+' '+number_chose.get())
label1=ttk.Label(win,text="Enter a name:").grid(row=0,column=0)
label2=ttk.Label(win,text="Choose a number:").grid(row=0,column=1)
# Adding a Text box Entry widget
name = tk.StringVar()
name_entered = ttk.Entry(win,width=12,textvariable=name)
name_entered.grid(row=1,column=0)
number = tk.StringVar()
number_chose = ttk.Combobox(win,width=12,textvariable=number)
number_chose['values'] = (1,2,4,42,56,100)
number_chose.grid(row=1,column=1)
number_chose.current(0)
# name_entered.focus()
btn = ttk.Button(win,text="Click me!",command=click_me)
btn.grid(row=1,column=2)
# Create three checkbuttons
chVarDis = tk.StringVar()
check1 = tk.Checkbutton(win,text="Disabled",variable=chVarDis,state='disabled')
check1.select()
check1.grid(row=2,column=0,sticky=tk.W)
chVarUn = tk.IntVar()
check2 = tk.Checkbutton(win,text="UnChecked",variable=chVarUn)
check2.deselect()
check2.grid(row=2,column=1,sticky=tk.W)
chVarEn = tk.IntVar()
check1 = tk.Checkbutton(win,text="Enable",variable=chVarEn)
check1.select()
check1.grid(row=2,column=2,sticky=tk.W)
# Start the GUI
win.mainloop()
代码运行后的界面如下:
下面在上面代码基础上构建单选按钮组件,代码如下:
import tkinter as tk
from tkinter import ttk
win = tk.Tk()
win.title("Python GUI Notes")
# Disable resizeing the GUI by passing in False/False
# win.resizable(False,False)
COLOR1 = "Blue"
COLOR2 = "Gold"
COLOR3 = "Red"
def click_me():
btn.configure(text='Hello '+ name.get()+' '+number_chose.get())
def radCall():
radSel = radVar.get()
if radSel == 1: win.configure(background=COLOR1)
elif radSel == 2: win.configure(background=COLOR2)
elif radSel == 3: win.configure(background=COLOR3)
pass
label1=ttk.Label(win,text="Enter a name:").grid(row=0,column=0)
label2=ttk.Label(win,text="Choose a number:").grid(row=0,column=1)
# Adding a Text box Entry widget
name = tk.StringVar()
name_entered = ttk.Entry(win,width=12,textvariable=name)
name_entered.grid(row=1,column=0)
number = tk.StringVar()
number_chose = ttk.Combobox(win,width=12,textvariable=number)
number_chose['values'] = (1,2,4,42,56,100)
number_chose.grid(row=1,column=1)
number_chose.current(0)
# name_entered.focus()
btn = ttk.Button(win,text="Click me!",command=click_me)
btn.grid(row=1,column=2)
# Create three checkbuttons
chVarDis = tk.StringVar()
check1 = tk.Checkbutton(win,text="Disabled",variable=chVarDis,state='disabled')
check1.select()
check1.grid(row=2,column=0,sticky=tk.W)
chVarUn = tk.IntVar()
check2 = tk.Checkbutton(win,text="UnChecked",variable=chVarUn)
check2.deselect()
check2.grid(row=2,column=1,sticky=tk.W)
chVarEn = tk.IntVar()
check1 = tk.Checkbutton(win,text="Enable",variable=chVarEn)
check1.select()
check1.grid(row=2,column=2,sticky=tk.W)
# Radiobutton
radVar = tk.IntVar()
rad1 = tk.Radiobutton(win,text=COLOR1,variable=radVar,value=1,command=radCall)
rad1.grid(row=3,column=0,sticky=tk.W,columnspan=3)
rad2 = tk.Radiobutton(win,text=COLOR2,variable=radVar,value=2,command=radCall)
rad2.grid(row=3,column=1,sticky=tk.W,columnspan=3)
rad1 = tk.Radiobutton(win,text=COLOR3,variable=radVar,value=3,command=radCall)
rad1.grid(row=3,column=2,sticky=tk.W,columnspan=3)
# Start the GUI
win.mainloop()
代码运行后如下:
点击后的效果如下:
当然由于逐个创建上述单选按钮组件比较麻烦,我们可以采用循环的方式进行创建,相应代码如下:
import tkinter as tk
from tkinter import ttk
win = tk.Tk()
win.title("Python GUI Notes")
# Disable resizeing the GUI by passing in False/False
# win.resizable(False,False)
colors = ["Blue","Gold","Red"]
def click_me():
btn.configure(text='Hello '+ name.get()+' '+number_chose.get())
def radCall():
radSel = radVar.get()
if radSel == 0: win.configure(background=colors[0])
elif radSel == 1: win.configure(background=colors[1])
elif radSel == 2: win.configure(background=colors[2])
pass
label1=ttk.Label(win,text="Enter a name:").grid(row=0,column=0)
label2=ttk.Label(win,text="Choose a number:").grid(row=0,column=1)
# Adding a Text box Entry widget
name = tk.StringVar()
name_entered = ttk.Entry(win,width=12,textvariable=name)
name_entered.grid(row=1,column=0)
number = tk.StringVar()
number_chose = ttk.Combobox(win,width=12,textvariable=number)
number_chose['values'] = (1,2,4,42,56,100)
number_chose.grid(row=1,column=1)
number_chose.current(0)
# name_entered.focus()
btn = ttk.Button(win,text="Click me!",command=click_me)
btn.grid(row=1,column=2)
# Create three checkbuttons
chVarDis = tk.StringVar()
check1 = tk.Checkbutton(win,text="Disabled",variable=chVarDis,state='disabled')
check1.select()
check1.grid(row=2,column=0,sticky=tk.W)
chVarUn = tk.IntVar()
check2 = tk.Checkbutton(win,text="UnChecked",variable=chVarUn)
check2.deselect()
check2.grid(row=2,column=1,sticky=tk.W)
chVarEn = tk.IntVar()
check1 = tk.Checkbutton(win,text="Enable",variable=chVarEn)
check1.select()
check1.grid(row=2,column=2,sticky=tk.W)
# Radiobutton
radVar = tk.IntVar()
radVar.set(99)
for col in range(3):
radbtn=tk.Radiobutton(win,text=colors[col],variable=radVar,value=col,command=radCall)
radbtn.grid(row=3,column=col,sticky=tk.W)
# Start the GUI
win.mainloop()