python基于Tkinter库实现简单文本编辑器实例


Posted in Python onMay 05, 2015

本文实例讲述了python基于Tkinter库实现简单文本编辑器的方法。分享给大家供大家参考。具体实现方法如下:

## {{{ http://code.activestate.com/recipes/578568/ (r1)
from Tkinter import * 
from tkSimpleDialog import askstring
from tkFileDialog  import asksaveasfilename
from tkMessageBox import askokcancel     
class Quitter(Frame):            
  def __init__(self, parent=None):     
    Frame.__init__(self, parent)
    self.pack()
    widget = Button(self, text='Quit', command=self.quit)
    widget.pack(expand=YES, fill=BOTH, side=LEFT)
  def quit(self):
    ans = askokcancel('Verify exit', "Really quit?")
    if ans: Frame.quit(self)
class ScrolledText(Frame):
  def __init__(self, parent=None, text='', file=None):
    Frame.__init__(self, parent)
    self.pack(expand=YES, fill=BOTH)        
    self.makewidgets()
    self.settext(text, file)
  def makewidgets(self):
    sbar = Scrollbar(self)
    text = Text(self, relief=SUNKEN)
    sbar.config(command=text.yview)         
    text.config(yscrollcommand=sbar.set)      
    sbar.pack(side=RIGHT, fill=Y)          
    text.pack(side=LEFT, expand=YES, fill=BOTH)   
    self.text = text
  def settext(self, text='', file=None):
    if file: 
      text = open(file, 'r').read()
    self.text.delete('1.0', END)          
    self.text.insert('1.0', text)         
    self.text.mark_set(INSERT, '1.0')       
    self.text.focus()                
  def gettext(self):                
    return self.text.get('1.0', END+'-1c')     
class SimpleEditor(ScrolledText):            
  def __init__(self, parent=None, file=None): 
    frm = Frame(parent)
    frm.pack(fill=X)
    Button(frm, text='Save', command=self.onSave).pack(side=LEFT)
    Button(frm, text='Cut',  command=self.onCut).pack(side=LEFT)
    Button(frm, text='Paste', command=self.onPaste).pack(side=LEFT)
    Button(frm, text='Find', command=self.onFind).pack(side=LEFT)
    Quitter(frm).pack(side=LEFT)
    ScrolledText.__init__(self, parent, file=file) 
    self.text.config(font=('courier', 9, 'normal'))
  def onSave(self):
    filename = asksaveasfilename()
    if filename:
      alltext = self.gettext()           
      open(filename, 'w').write(alltext)     
  def onCut(self):
    text = self.text.get(SEL_FIRST, SEL_LAST)    
    self.text.delete(SEL_FIRST, SEL_LAST)      
    self.clipboard_clear()       
    self.clipboard_append(text)
  def onPaste(self):                  
    try:
      text = self.selection_get(selection='CLIPBOARD')
      self.text.insert(INSERT, text)
    except TclError:
      pass                   
  def onFind(self):
    target = askstring('SimpleEditor', 'Search String?')
    if target:
      where = self.text.search(target, INSERT, END) 
      if where:                  
        print where
        pastit = where + ('+%dc' % len(target))  
        #self.text.tag_remove(SEL, '1.0', END)   
        self.text.tag_add(SEL, where, pastit)   
        self.text.mark_set(INSERT, pastit)     
        self.text.see(INSERT)          
        self.text.focus()            
if __name__ == '__main__':
  try:
    SimpleEditor(file=sys.argv[1]).mainloop()  
  except IndexError:
    SimpleEditor().mainloop()

希望本文所述对大家的Python程序设计有所帮助。

Python 相关文章推荐
使用setup.py安装python包和卸载python包的方法
Nov 27 Python
Python 分析Nginx访问日志并保存到MySQL数据库实例
Mar 13 Python
在Python的循环体中使用else语句的方法
Mar 30 Python
用Python的Django框架来制作一个RSS阅读器
Jul 22 Python
Python+树莓派+YOLO打造一款人工智能照相机
Jan 02 Python
numpy.linspace函数具体使用详解
May 27 Python
python之拟合的实现
Jul 19 Python
python实现批量修改文件名
Mar 23 Python
tensorflow模型文件(ckpt)转pb文件的方法(不知道输出节点名)
Apr 22 Python
tensorflow 20:搭网络,导出模型,运行模型的实例
May 26 Python
Python pytesseract验证码识别库用法解析
Jun 29 Python
pandas使用函数批量处理数据(map、apply、applymap)
Nov 27 Python
python实现的简单窗口倒计时界面实例
May 05 #Python
给Python中的MySQLdb模块添加超时功能的教程
May 05 #Python
用Python实现一个简单的多线程TCP服务器的教程
May 05 #Python
简单介绍Python中的try和finally和with方法
May 05 #Python
python中的闭包用法实例详解
May 05 #Python
Python闭包实现计数器的方法
May 05 #Python
深入探究Python中变量的拷贝和作用域问题
May 05 #Python
You might like
PHP 第二节 数据类型之数值型
2012/04/28 PHP
PHP+JQUERY操作JSON实例
2017/03/23 PHP
PHP后期静态绑定实例浅析
2018/12/21 PHP
基于thinkphp6.0的success、error实现方法
2019/11/05 PHP
Javascript中找到子元素在父元素内相对位置的代码
2012/07/21 Javascript
javascript中interval与setTimeOut的区别示例介绍
2014/03/14 Javascript
基于Jquery+Ajax+Json实现分页显示附效果图
2014/07/30 Javascript
原生javaScript实现图片延时加载的方法
2014/12/22 Javascript
JavaScript之AOP编程实例
2015/07/17 Javascript
js省市县三级联动效果实例
2020/04/15 Javascript
JavaScript结合Bootstrap仿微信后台多图文界面管理
2016/07/22 Javascript
详谈commonjs模块与es6模块的区别
2017/10/18 Javascript
微信小程序实现动态设置placeholder提示文字及按钮选中/取消状态的方法
2017/12/14 Javascript
Angular2.0实现modal对话框的方法示例
2018/02/18 Javascript
实例讲解JavaScript截取字符串
2018/11/30 Javascript
基于Vue 实现一个中规中矩loading组件
2019/04/03 Javascript
vue中axios实现数据交互与跨域问题
2019/05/12 Javascript
JavaScript代码实现简单计算器
2020/12/27 Javascript
Python3匿名函数用法示例
2018/07/25 Python
Python图像处理实现两幅图像合成一幅图像的方法【测试可用】
2019/01/04 Python
python下载微信公众号相关文章
2019/02/26 Python
Python基础学习之基本数据结构详解【数字、字符串、列表、元组、集合、字典】
2019/06/18 Python
利用python求积分的实例
2019/07/03 Python
python实现图像拼接功能
2020/03/23 Python
Jupyter Notebook 远程访问配置详解
2021/01/11 Python
英国浴室洗脸盆购物网站:Click Basin
2018/06/08 全球购物
大学毕业生通用自我评价
2014/01/05 职场文书
组织关系转移介绍信
2014/01/16 职场文书
安全教育感言
2014/03/04 职场文书
《雨点儿》教学反思
2014/04/14 职场文书
2014年幼儿园重阳节活动方案
2014/09/16 职场文书
工作检讨书大全
2015/01/26 职场文书
求职自荐信范文(优秀篇)
2015/03/27 职场文书
python 如何在list中找Topk的数值和索引
2021/05/20 Python
一文读懂navicat for mysql基础知识
2021/05/31 MySQL
MySQL 用 limit 为什么会影响性能
2021/09/15 MySQL