Python开发简单记事本

摘要:

本文是使用Python,结合Tkinter开发简单记事本。

  本文的操作环境:ubuntu,Python2.7,采用的是Pycharm进行代码编辑,个人很喜欢它的代码自动补齐功能。

  最近很想对python加深学习一下,同时也是想试着做一些东西,今天使用python,结合Tkinter来做一个简单的跨平台记事本。最终实现的记事本如下,也算是麻雀虽小,五脏俱全了,之后也是会继续完善的:

  如上图,我们可以看到这个记事本主要分为三个模块:文件,编辑和关于,结合我自身的习惯外加四个toolbar:新建、打开、撤销和保存。下来就我个人构建这个记事本做个总结。

一 整体框架构建

1.三个主模块的建立

  首先,我们先建立上图中的三个主模块,同时,在模块中建立各个模块的功能。先以文件为例:下设功能:新建、打开、保存和另存为,代码如下:

#-*-encoding:utf8
from Tkinter import *

root = Tk()
root.title(‘Benben Node‘)

#create menu
menubar = Menu(root)
root.config(menu = menubar)

filemenu = Menu(menubar)
filemenu.add_command(label = ‘新建‘,accelerator =‘ctrl + N‘)
filemenu.add_command(label = ‘打开‘,accelerator =‘ctrl + O‘)
filemenu.add_command(label = ‘保存‘,accelerator =‘ctrl + S‘)
filemenu.add_command(label = ‘另存为‘,accelerator =‘ctrl + Shift + s‘)
menubar.add_cascade(label = ‘文件‘,menu = filemenu)

root.mainloop()

运行结果:

  我们可以看到一个简单的文件栏就建好了。对应的建立编辑和关于模块。编辑指的是对文本编辑中要使用的模块,下设功能:撤销,重做,复制,剪切,粘贴,查找和全选;关于是下设作者和版权两栏。相应模块对应的代码如下:

#编辑
editmenu = Menu(menubar)
editmenu.add_command(label = ‘撤销‘,accelerator = ‘ctrl + z‘)
editmenu.add_command(label = ‘重做‘,accelerator = ‘ctrl + y‘)
editmenu.add_command(label = ‘复制‘,accelerator = ‘ctrl + c‘)
editmenu.add_command(label = ‘剪切‘,accelerator = ‘ctrl + x‘)
editmenu.add_command(label = ‘粘贴‘,accelerator = ‘ctrl + v‘)
editmenu.add_command(label = ‘查找‘,accelerator = ‘ctrl + F‘)
editmenu.add_command(label = ‘全选‘,accelerator = ‘ctrl + A‘)
menubar.add_cascade(label = ‘编辑‘,menu = editmenu)

#关于
aboutmenu = Menu(menubar)
aboutmenu.add_command(label = ‘作者‘)
aboutmenu.add_command(label = ‘版权‘)
menubar.add_cascade(label = ‘关于‘,menu = aboutmenu)

运行结果:

截图未能得到各个模块对应的功能。

2.toolbar

  在记事本中添加toolbar,添加对应的button并设定合适的间距,对应的代码如下:

#toolbartoolbar = Frame(root,height = 15,bg = ‘SkyBlue‘)shortButton = Button(toolbar,text = ‘新建‘,command = open)shortButton.pack(side = LEFT)shortButton = Button(toolbar,text = ‘打开‘,command = openfile)shortButton.pack(side = LEFT,padx = 5,pady = 5)shortButton = Button(toolbar,text = ‘保存‘,command = save)shortButton.pack(side = RIGHT)shortButton = Button(toolbar,text = ‘撤销‘,command = undo)shortButton.pack(side = RIGHT,padx = 5,pady = 5)toolbar.pack(expand = NO,fill = X)

3.创建状态栏(statusbar)和正文编辑区域

首先在程序中添加:

root = Tk()
root.title(‘Benben Node‘)
root.geometry("800x500+100+100")

编辑状态栏的代码:

#statusbar
status = Label(root,text = ‘Ln20‘,bd = 1,relief = SUNKEN,anchor = ‘w‘)
status.pack(side = BOTTOM,fill = X)

当然我们还可以建立相应的编辑区域和滚动条,对应的代码如下:

#正文编辑区域
lnlabel = Label(root,width = 2,bg = ‘antique white‘)
lnlabel.pack(side = LEFT,fill = Y)

textpad = Text(root,undo = True)
textpad.pack(expand = YES,fill = BOTH)

scroll = Scrollbar(textpad)
textpad.config(yscrollcommand = scroll.set)
scroll.config(command = textpad.yview)
scroll.pack(side = RIGHT,fill = Y)

  执行代码,结果:

输入相应的可以看到右边界对应的滚动条随输入滚动。

二. 关于模块的实现

  在这三个模块中,关于是最好实现的一个,那就从最简单的开始实现吧。对应的代码如下:

from tkMessageBox import *

#关于
def author():
    showinfo(‘作者信息‘,‘本软件由可爱的奔奔完成‘)
def about():
    showinfo(‘版权信息.copyright‘,‘版权属于奔奔‘)

aboutmenu = Menu(menubar)
aboutmenu.add_command(label = ‘作者‘,command = author)
aboutmenu.add_command(label = ‘版权‘,command = about)
menubar.add_cascade(label = ‘关于‘,menu = aboutmenu)

运行结果:

     

三.文件模块的实现

  这部分的实现参见Tkinter官网中的fileDialogs,相应的使用各个方法实现功能:新建、打开、保存和另存为,建立相应的函数实现,代码如下:

#新建
def new():
    root.title(‘未命名文件‘)
    filename = None
    textpad.delete(1.0,END)
#打开
def openfile():
    global filename
    filename = askopenfilename(defaultextension = ‘.txt‘)
    if filename == ‘‘:
        filename = None
    else:
        root.title(‘FileName:‘+os.path.basename(filename))
        textpad.delete(1.0,END)
        f = open(filename,‘r‘)
        textpad.insert(1.0,f.read())
        f.close()

#保存
def save():
    global filename
    try:
        f = open(filename,‘w‘)
        msg = textpad.get(1.0,END)
        f.write(msg)
        f.close()
    except:
        saveas()
#另存为
def saveas():
    f = asksaveasfilename(initialfile= ‘未命名.txt‘, defaultextension=‘.txt‘)
    global filename
    filename = f
    fh = open(f,‘w‘)
    msg = textpad.get(1.0,END)
    fh.write(msg)
    fh.close()
    root.title(‘FileName:‘+os.path.basename(f))

  相应的在filemenu和toolbar中加入对应的command,运行结果:

  

四 编辑模块的实现

  编辑要实现的功能:撤销,重做,复制,剪切,粘贴,查找和全选,对应的函数代码如下:

def cut():
    textpad.event_generate(‘<<Cut>>‘)

def copy():
    textpad.event_generate(‘<<Copy>>‘)

def paste():
    textpad.event_generate(‘<<Paste>>‘)

def redo():
    textpad.event_generate(‘<<Redo>>‘)

def undo():
    textpad.event_generate(‘<<Undo>>‘)

def selectAll():
    textpad.tag_add(‘sel‘,‘1.0‘,END)

def search():
    topsearch = Toplevel(root)
    topsearch.geometry(‘300x30+200+250‘)
    label1 = Label(topsearch,text=‘Find‘)
    label1.grid(row=0, column=0,padx=5)
    entry1 = Entry(topsearch,width=20)
    entry1.grid(row=0, column=1,padx=5)
    button1 = Button(topsearch,text=‘查找‘)
    button1.grid(row=0, column=2)

  同样在editmenu和toolbar中加入对应的command。运行代码,功能实现!快捷键亲测可用~

  这算是对此次开发的简单记事本的一个总结,之后有时间也是会添加更多的功能。

时间: 2024-10-06 16:39:28

Python开发简单记事本的相关文章

Python开发简单爬虫

可关注我的个人微信公众号:卟野iiiiiiiya Python开发简单爬虫: https://mp.weixin.qq.com/s?__biz=MzI0MDY0NzI3Mw==&tempkey=OTMwX3pMejY4VFdoVlQ1cWpyNXNYdFhqcWViaHY1bFlQUTdmU1RrUnpkc1IzQmNfWENHVXFZb2ZLajhURlFyZmZaa3JVOHRkYkJaZVF1ZXVmdk5nUHFFNU0xeVAyQm1rMnlLbVJGa3h4eTBpMjNVdnc3b

Python 开发简单爬虫 - 基础框架

1. 目标:开发轻量级爬虫(不包括需登陆的 和 Javascript异步加载的) 不需要登陆的静态网页抓取 2. 内容: 2.1 爬虫简介 2.2 简单爬虫架构 2.3 URL管理器 2.4 网页下载器(urllib2) 2.5 网页解析器(BeautifulSoup) 2.6 完整实例:爬取百度百科Python词条相关的1000个页面数据 3. 爬虫简介:一段自动抓取互联网信息的程序 爬虫价值:互联网数据,为我所用. 4. 简单爬虫架构: 运行流程: 5. URL管理器:管理待抓取URL集合

Python开发简单爬虫(二)---爬取百度百科页面数据

一.开发爬虫的步骤 1.确定目标抓取策略: 打开目标页面,通过右键审查元素确定网页的url格式.数据格式.和网页编码形式. ①先看url的格式, F12观察一下链接的形式;② 再看目标文本信息的标签格式, 比如文本数据为div class="xxx", ③ 容易看到编码为utf-8 2.分析目标 目标: 百度百科python词条 入口页: http://baike.baidu.com/item/Python词条页面url格式:/item/**** 数据格式: 标题: <dd cl

python 开发简单的聊天工具-乾颐堂

python 太强大了,以至于它什么都可以做,哈哈,开个玩笑.但是今天要讲的真的是一个非常神奇的应用. 使用python写一个聊天工具 其实大家平时用的QQ类似的聊天工具,也是使用socket进行聊天,只是它还包含了更加复杂的功能.基本原理是一样的. python实现聊天功能,主要用到了socket模块.下面直接上实例吧 server端 1 2 3 4 5 6 7 8 9 10 11 12 13 import socket s=socket.socket() #建立socket链接 s.bind

Python开发简单爬虫(一)

一 .简单爬虫架构: 爬虫调度端:启动爬虫,停止爬虫,监视爬虫运行情况 URL管理器:对将要爬取的和已经爬取过的URL进行管理:可取出带爬取的URL,将其传送给“网页下载器” 网页下载器:将URL指定的网页下载,存储成一个字符串,在传送给“网页解析器” 网页解析器:解析网页可解析出 ①有价值的数据 ②另一方面,每个网页都包含有指向其他网页的URL,解析出来后可补充进“URL管理器”,不断循环. 二.简单爬虫架构的动态运行流程 三.爬虫URL管理 URL管理器:管理待抓取URL集合和已抓取URL集

python 开发简单的聊天工具

python 太强大了,以至于它什么都可以做,哈哈,开个玩笑.但是今天要讲的真的是一个非常神奇的应用. 使用python写一个聊天工具 其实大家平时用的QQ类似的聊天工具,也是使用socket进行聊天,只是它还包含了更加复杂的功能.基本原理是一样的. python实现聊天功能,主要用到了socket模块.下面直接上实例吧 server端 1 2 3 4 5 6 7 8 9 10 11 12 13 import socket s=socket.socket() #建立socket链接 s.bind

Python 开发简单爬虫 - 实战演练

爬取百度百科1000个页面的数据 1. 准备工作: 确定目标  =>  分析目标(URL格式, 数据格式, 网页编码) =>  编写代码  =>  执行爬虫 1.1 链接分析: 进入百度百科"Python"词条页面:http://baike.baidu.com/view/21087.htm => 在链接位置右键后,点击审查元素, href="/view/2561555.htm" 是一个不完整的url, 在代码中需要拼接成完整的 baike.b

Python开发简单爬虫之静态网页抓取篇:爬取“豆瓣电影 Top 250”电影数据

目标:爬取豆瓣电影TOP250的所有电影名称,网址为:https://movie.douban.com/top250 1)确定目标网站的请求头: 打开目标网站,在网页空白处点击鼠标右键,选择"检查".(小编使用的是谷歌浏览器). 点击"network",在弹出页面若长时间没有数据显示,则试一下F5刷新. 可以得到目标网页中Host和User-Agent两项. 2)找到爬取目标数据(即电影名称)在页面中的位置 右键"检查",选择"Elem

python之路——作业:开发简单的FTP

一.作业要求 开发简单的FTP:1. 用户登陆2. 上传/下载文件3. 不同用户家目录不同4. 查看当前目录下文件5. 充分使用面向对象知识 二.程序目录说明 FTP/ |-- FTPClient/ #客户端文件夹 | |-- 示例文件夹/ #客户端上传/下载示例文件夹 | |-- Client_start.py #客户端启动程序 | |-- FTPServer/ #服务端文件夹 | |-- bin/ | | |-- __init__.py | | |-- Server_start.py #程序