简介
1.tkinter是对Tcl/Tk的进一步封装,与tkinter.ttk和tkinter.tix共同提供了强大的跨平台GUI编程的功能
2.IDLE就是使用tkinter进行开发的
常用组件
- Button:按钮
- Canvas:画布,用于绘制直线,椭圆,多边形等各种图形
- Checkbutton:复选框形式的按钮
- Entry:单行文本框
- Frame:框架,可作为其他组件的容器,常用来对组件进行分组
- Label:标签,常用来显示单行文本
- Listbox:列表框
- Menu:菜单
- Message:多行文本框
- Rediobutton:单选钮,同一组中的单选钮任何时刻只能有一个处于选中状态
- Scrollbar:滚动条
- Toplevel:常用来创建新的窗口
流程框架
1.根据需要导入需要的模块
import tkinter
import tkinter.ttk
import tkinter.messagebox
import tkinter.simpledialog
```
2.编写通用代码,或单独放置到另外的模块在导入
3.创建tkinter应用程序窗口
`root = tkinter.Tk()`
4.编写设置窗口属性的代码
5.编写创建窗口上各种组件的代码及按钮组合框等交互式组件的事件代码
6.启动消息主循环,启动应用程序
###简单的文本编辑器
```
import tkinter
import tkinter.filedialog
import tkinter.colorchooser
import tkinter.messagebox
import tkinter.scrolledtext
import tkinter.simpledialog
# 创建应用程序窗口
app = tkinter.Tk()
app.title('李毛毛编辑器')
app['width'] = 800
app['height'] = 600
# 标记当前内容是否发生改变,是否需要保存
textChanged = tkinter.IntVar(app,value=0)
# 当前文件名
filename = ''
# 创建菜单
menu = tkinter.Menu(app)
# File子菜单
# tearoff=0表示该子菜单不可以独立
# tearoff=1时,子菜单顶端会有一个虚线
submenu = tkinter.Menu(menu,tearoff=0)
def Open():
# 声明全局变量
global filename
# 如果内容已经改变,先保存
if textChanged.get():
yesno = tkinter.messagebox.askyesno(title="Save or not?",message='Do you want to save?')
if yesno == tkinter.YES:
pass
#Save()
filename = tkinter.filedialog.askopenfilename(title='Open file',filetypes=[('Text files','*.txt')])
if filename:
# 清空内容,0.0是lineNumber.Column的表示方法
txtContent.delete(0.0,tkinter.END)
with open(filename,'r') as fp:
txtContent.insert(tkinter.INSERT,''.join(fp.readlines()))
# 标记为尚无修改
textChanged.set(0)
# 创建open菜单并绑定菜单事件处理函数
submenu.add_command(label="Open",command=Open)
def Save():
global filename
# 如果是第一次打开保存新建文件,则打开"另存为"窗口
if not filename:
SaveAs()
# 如果内容发生改变,保存
elif textChanged.get():
with open(filename,'w') as fp:
fp.write(txtContent.get(0.0,tkinter.END))
textChanged.set(0)
submenu.add_command(label="Save",command=Save)
def SaveAs():
global filename
# 打开另存为窗口
newfilename = tkinter.filedialog.asksaveasfilename(title='Save As',initialdir=r'/home',initialfile='new.txt')
# 如果指定了文件名,则保存文件
if newfilename:
with open(newfilename,'w') as fp:
fp.write(txtContent.get(0.0,tkinter.END))
filename = newfilename
textChanged.set(0)
submenu.add_command(label="Save As",command=SaveAs)
# 菜单添加分割线
submenu.add_separator()
def Close():
global filename
Save()
txtContent.delete(0.0,tkinter.END)
# 置空文件名
filename = ''
submenu.add_command(label="Close",command=Close)
# 将子菜单关联到主菜单上
menu.add_cascade(label='File',menu=submenu)
# Edit子菜单
submenu = tkinter.Menu(menu,tearoff=0)
# 撤销最后一次操作
def Undo():
# 启用Undo标志
txtContent['undo'] = True
try:
txtContent.edit_undo()
except Exception as e:
pass
submenu.add_command(label="Undo",command=Undo)
def Redo():
txtContent['undo'] = True
try:
txtContent.edit_redo()
except Exception as e:
pass
submenu.add_command(label='Redo',command=Redo)
submenu.add_separator()
def Copy():
txtContent.clipboard_clear()
txtContent.clipboard_append(txtContent.selection_get())
submenu.add_command(label='Copy',command=Copy)
def Cut():
Copy()
# 删除所选内容
txtContent.delete(tkinter.SEL_FIRST,tkinter.SEL_LAST)
submenu.add_command(label='Cut',command=Cut)
def Paste():
# 如果没有选中内容,则直接粘贴到鼠标位置
# 如果有所选内容,则先删除再粘贴
try:
txtContent.insert(tkinter.SEL_FIRST,txtContent.clipboard_get())
txtContent.delete(tkinter.SEL_FIRST,tkinter.SEL_LAST)
# 如果粘贴成功就结束本函数,以免异常处理执行完成后再次粘贴
return
except Exception as e:
pass
txtContent.insert(tkinter.INSERT,txtContent.clipboard_get())
submenu.add_command(label='Paste',command=Paste)
submenu.add_separator()
def Search():
testToSearch = tkinter.simpledialog.askstring(title='Search',prompt='What to search ?')
start = txtContent.search(testToSearch,0.0,tkinter.END)
if start:
tkinter.messagebox.showinfo(title='Found',message='Ok')
else:
tkinter.messagebox.showerror(title='Not Found',message='Fail')
submenu.add_command(label='Search',command=Search)
menu.add_cascade(label='Edit',menu=submenu)
#help菜单
submenu = tkinter.Menu(menu,tearoff=0)
def About():
tkinter.messagebox.showinfo(title='About',message='作者:李毛毛\n微信公众号:李毛毛学Python\n博客地址:http://rskdwypy.lofter.com')
submenu.add_command(label='About',command=About)
menu.add_cascade(label='Help',menu=submenu)
# 将创建的菜单关联到应用程序窗口
app.config(menu=menu)
# 创建文本编辑组件
txtContent = tkinter.scrolledtext.ScrolledText(app,wrap=tkinter.WORD)
txtContent.pack(fill=tkinter.BOTH,expand=tkinter.YES)
def KeyPress(event):
textChanged.set(1)
txtContent.bind('<KeyPress>',KeyPress)
app.mainloop()