Python 的Tkinter包系列之七:好例子补充2

news2025/1/11 0:32:51

Python 的Tkinter包系列之七:好例子补充2

英汉字典(使用文本文件记录英语单词和解释)、简单的通信录(使用SQLite数据库记录人员信息)

一、tkinter编写英汉字典

先看效果图:

词典文件是一个文本文件,我这里起的名字是:CET-4.txt格式如下

每个词占用一行,单词和解释之间用*分割 例如:

a * art.一(个);每一(个)       

abandon * vt.丢弃;放弃,抛弃       

ability * n.能力;能耐,本领       

able * a.有能力的;出色的

baby * n.婴儿;孩子气的人       

back * ad.在后;回原处;回       

background * n.背景,后景,经历

cabinet * n.橱,柜;内阁       

cable * n.缆,索;电缆;电报       

cafe * n.咖啡馆;小餐厅  

为方便,我这里将CET-4.txt和下面的源码文件放到同一个目录(文件夹)中。

源码如下: 

#tkinter编写英汉字典
import tkinter

# 读取内容并执行搜索的方法
def search(word):
    # 读取字典内所有内容
    file = open("CET-4.txt")  #指定打开文件的编码格式 utf-8
    dict_list = file.readlines()
    # 遍历读取的内容,查看用户输入的英文是否存在
    for dict00 in dict_list:
        dict_item = dict00.split("*")
        # 不区分大小写查询,查询到就输出英文和中文;strip()把字符串头和尾的空格去掉
        if word.upper().strip() == dict_item[0].upper().strip():
            # 把查询的内容返回并结束循环
            return "%s: %s" % (dict_item[0], dict_item[1])
    else:
        return "您查询的单词尚未收录,敬请期待。。。\n"
    # 关闭流
    file.close()


def search_word():
    word = entry.get().strip()
    if len(word) != 0:
        # 执行搜索的方法,获取搜索的结果
        result = search(word)
        # 把结果插入到文本显示框
        txt.insert(tkinter.INSERT, result)
    else:
        txt.insert(tkinter.INSERT, "内容不能为空\n")


# 创建主窗口
window = tkinter.Tk()

# 添加标题
window.title("XX字典")

# 设置窗口尺寸
window.geometry("400x300")

# 内容输入块
frame_input = tkinter.Frame(window, width=300, height=30)
frame_input.place(x=50, y=10)

# 输入框
entry = tkinter.Entry(frame_input, width=30)
entry.pack(side="left")

# 按钮
btn_in = tkinter.Button(frame_input, text="查询", width=5, command=search_word)
btn_in.pack(side="right", padx=5)

# 文本显示块
frame_txt = tkinter.Frame(window, width=350, height=200)
frame_txt.place(x=20, y=40)

# 文本显示框的滚动条
scroll_bar = tkinter.Scrollbar(frame_txt)
scroll_bar.pack(side="right", fill=tkinter.Y)

# 内容显示框
txt = tkinter.Text(frame_txt, width=50, height=18)
txt.pack(side="bottom", pady=15)

# 关联滚动条和文字
txt.config(yscrollcommand=scroll_bar.set)
scroll_bar.config(command=txt.yview)

# 显示
window.mainloop()

提示:使用 open() 打开文件时,中文windows系统默认采用 GBK 编码。但当要打开的文件不是 GBK 编码格式时,运行出错,可以指定打开文件的编码格式,例如:

file = open("a.txt",encoding="utf-8")

注意, encoding 参数的值,仅限于文件以文本的形式打开,也就是说,以二进制格式打开时,不能用 encoding 参数。

二、简单的通信录

使用tkinter开发一个带界面的简单的通信录管理系统

先看效果图:

使用SQLite数据库记录人员信息。

SQLite是轻量级、基于文件的数据库管理系统。Python自带Sqlite3数据库。要用Python操作SQLite,不用下载SQLite,只要先import sqlite3后,即可操作SQLite。可参见详见https://blog.csdn.net/cnds123/article/details/106372967

首先使用SQLite工具创建SQLite数据库data.db,然后创建一个数据表addressList,最后在数据表addressList中创建字段id(INTEGER PRIMARY KEY类型)、name(TEXT类型)、sex(TEXT类型)、age(INTEGER类型)、department(TEXT类型)、telephone(TEXT类型)和qq(TEXT类型)。

 下面给出源码

import sqlite3
import tkinter
import tkinter.ttk
import tkinter.messagebox

def doSql(sql):
    '''用来执行SQL语句,尤其是INSERT和DELETE语句'''    
    conn = sqlite3.connect('data.db')
    cur = conn.cursor()
    cur.execute(sql)
    conn.commit()
    conn.close()

#创建tkinter应用程序窗口
root = tkinter.Tk()
#设置窗口大小和位置
root.geometry('500x500+400+300')
#不允许改变窗口大小
root.resizable(False, False)
#设置窗口标题
root.title('通信录管理系统')

#在窗口上放置标签组件和用于输入姓名的文本框组件
lbName = tkinter.Label(root, text='姓名:')
lbName.place(x=10, y=10, width=40, height=20)
entryName = tkinter.Entry(root)
entryName.place(x=60, y=10, width=150, height=20)

#在窗口上放置标签组件和用于选择性别的组合框组件
lbSex = tkinter.Label(root, text='性别:')
lbSex.place(x=220, y=10, width=40, height=20)
comboSex = tkinter.ttk.Combobox(root, values=('男', '女'))
comboSex.place(x=270, y=10, width=150, height=20)

#在窗口上放置标签组件和用于输入年龄的文本框组件
lbAge = tkinter.Label(root, text='年龄:')
lbAge.place(x=10, y=50, width=40, height=20)
entryAge = tkinter.Entry(root)
entryAge.place(x=60, y=50, width=150, height=20)

#在窗口上放置标签组件和用于输入部门的文本框组件
lbDepartment = tkinter.Label(root, text='部门:')
lbDepartment.place(x=220, y=50, width=40, height=20)
entryDepartment = tkinter.Entry(root)
entryDepartment.place(x=270, y=50, width=150, height=20)

#在窗口上放置标签组件和用于输入电话号码的文本框组件
lbTelephone = tkinter.Label(root, text='电话:')
lbTelephone.place(x=10, y=90, width=40, height=20)
entryTelephone = tkinter.Entry(root)
entryTelephone.place(x=60, y=90, width=150, height=20)

#在窗口上放置标签组件和用于输入QQ号码的文本框组件
lbQQ = tkinter.Label(root, text='QQ:')
lbQQ.place(x=220, y=90, width=40, height=20)
entryQQ = tkinter.Entry(root)
entryQQ.place(x=270, y=90, width=150, height=20)

#在窗口上放置用来显示通信录信息的表格,使用Treeview组件实现
frame = tkinter.Frame(root)
frame.place(x=0, y=180, width=480, height=280)
#滚动条
scrollBar = tkinter.Scrollbar(frame)
scrollBar.pack(side=tkinter.RIGHT, fill=tkinter.Y)
#Treeview组件,分别设置6列的标题和宽度
treeAddressList = tkinter.ttk.Treeview(frame,
                                       columns=('c1', 'c2', 'c3','c4', 'c5', 'c6'),
                                       show="headings",
                                       yscrollcommand = scrollBar.set)
treeAddressList.column('c1', width=70, anchor='center')
treeAddressList.column('c2', width=40, anchor='center')
treeAddressList.column('c3', width=40, anchor='center')
treeAddressList.column('c4', width=120, anchor='center')
treeAddressList.column('c5', width=100, anchor='center')
treeAddressList.column('c6', width=90, anchor='center')
treeAddressList.heading('c1', text='姓名')
treeAddressList.heading('c2', text='性别')
treeAddressList.heading('c3', text='年龄')
treeAddressList.heading('c4', text='部门')
treeAddressList.heading('c5', text='电话')
treeAddressList.heading('c6', text='QQ')
treeAddressList.pack(side=tkinter.LEFT, fill=tkinter.Y)
#Treeview组件与垂直滚动条结合
scrollBar.config(command=treeAddressList.yview)

def bindData():
    '''把数据库里的通信录记录读取出来,然后在表格中显示'''
    #删除表格中原来的所有行
    for row in treeAddressList.get_children():
        treeAddressList.delete(row)
    #读取数据
    conn = sqlite3.connect('data.db')
    cur = conn.cursor()
    cur.execute('SELECT * FROM addressList ORDER BY id ASC')
    temp = cur.fetchall()
    conn.close()

    #把数据插入表格
    for i, item in enumerate(temp):
        treeAddressList.insert('', i, values=item[1:])
#调用函数,把数据库中的记录显示到表格中
bindData()

#定义Treeview组件的左键单击事件,并绑定到Treeview组件上
#单击鼠标左键,设置变量nameToDelete的值,然后可以使用“删除”按钮来删除
nameToDelete = tkinter.StringVar()
def treeviewClick(event):
    if not treeAddressList.selection():
        return
    item = treeAddressList.selection()[0]
    nameToDelete.set(treeAddressList.item(item, 'values')[0])
treeAddressList.bind('<Button-1>', treeviewClick)


#在窗口上放置用于添加通信录的按钮,并设置按钮单击事件函数
def buttonAddClick():
    #检查姓名
    name = entryName.get().strip()
    if name == '':
        tkinter.messagebox.showerror(title='很抱歉', message='必须输入姓名')
        return
    #姓名不能重复
    conn = sqlite3.connect('data.db')
    cur = conn.cursor()
    cur.execute('SELECT COUNT(id) from addressList where name="' + name + '"')
    c = cur.fetchone()[0]
    conn.close()
    if c!=0:
        tkinter.messagebox.showerror(title='很抱歉', message='姓名不能重复')
        return
    #获取选择的性别
    sex = comboSex.get()
    #检查年龄
    age = entryAge.get().strip()
    if not age.isdigit():
        tkinter.messagebox.showerror(title='很抱歉', message='年龄必须为数字')
        return
    if not 1<int(age)<100:
        tkinter.messagebox.showerror(title='很抱歉',
                                 message='年龄必须在1到100之间')
        return
    #检查部门
    department = entryDepartment.get().strip()
    if department == '':
        tkinter.messagebox.showerror(title='很抱歉', message='必须输入部门')
        return
    #检查电话号码
    telephone = entryTelephone.get().strip()
    if telephone=='' or (not telephone.isdigit()):
        tkinter.messagebox.showerror(title='很抱歉',
                                     message='电话号码必须是数字')
        return
    #检查QQ号码
    qq = entryQQ.get().strip()
    if qq=='' or (not qq.isdigit()):
        tkinter.messagebox.showerror(title='很抱歉',
                                     message='QQ号码必须是数字')
        return
    #所有输入都通过检查,插入数据库
    sql = 'INSERT INTO addressList(name,sex,age,department,telephone,qq) VALUES("'
    sql += name + '","' + sex + '",' + age + ',"' + department + '","'
    sql += telephone + '","' + qq + '")'
    doSql(sql)
    #添加记录后,更新表格中的数据
    bindData()
buttonAdd = tkinter.Button(root, text='添加', command=buttonAddClick)
buttonAdd.place(x=120, y=140, width=80, height=20)

#在窗口上放置用于删除通信录的按钮,并设置按钮单击事件函数
def buttonDeleteClick():
    name = nameToDelete.get()
    if name == '':
        tkinter.messagebox.showerror(title='很抱歉', message='请选择一条记录')
        return
    #如果已经选择了一条通信录,执行SQL语句将其删除
    sql = 'DELETE FROM addressList where name="' + name + '"'
    doSql(sql)
    tkinter.messagebox.showinfo('恭喜', '删除成功')
    #重新设置变量为空字符串
    nameToDelete.set('')
    #更新表格中的数据
    bindData()
buttonDelete = tkinter.Button(root, text='删除', command=buttonDeleteClick)
buttonDelete.place(x=240, y=140, width=80, height=20)

root.mainloop()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/338487.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

python自动发送邮件实现

目录1 前言2 准备工作2.1 电子邮件的基础知识。2.2 python邮件库2.3 邮箱设置3 python实现邮件自动发送3.1 SMTP()和send()方法介绍3.2 python实现实例参考信息1 前言 python功能强大&#xff0c;可以实现我们日常办公的很多任务。诸如批量处理word,excel,pdf等等文件&#xf…

事务基础知识与执行计划

事务基础知识 数据库事务的概念 数据库事务是什么&#xff1f; 事务是一组原子性的SQL操作。事务由事务开始与事务结束之间执行的全部数据库操作组成。A&#xff08;原子性&#xff09;、&#xff08;C一致性&#xff09;、I&#xff08;隔离性&#xff09;、D&#xff08;持久…

1625_MIT 6.828 stabs文档信息整理_下

全部学习汇总&#xff1a; GreyZhang/g_unix: some basic learning about unix operating system. (github.com) 继续之前的学习笔记&#xff0c;整理一下最近看过的一点stabs资料。 这一页中有一半的信息是Fortran专用的&#xff0c;直接跳过。参数的符号修饰符是p&#xff0c…

【webpack】webpack 中的插件安装与使用

一、webpack 插件的作用 通过安装和配置第三方的插件&#xff0c;可以拓展 webpack 的能力&#xff0c;从而让 webpack 用起来更方便。最常用的 的webpack 插件有如下两个&#xff1a; 1.webpack-dev-server&#xff08;实时打包构建&#xff09; 类似于 node.js 阶段用到的 no…

为什么说网络安全是风口行业?

前言 “没有网络安全就没有国家安全”。当前&#xff0c;网络安全已被提升到国家战略的高度&#xff0c;成为影响国家安全、社会稳定至关重要的因素之一。 网络安全行业特点 1、就业薪资非常高&#xff0c;涨薪快 2021年猎聘网发布网络安全行业就业薪资行业最高人均33.77万&…

Django框架之模型

模型 当前项目的开发, 都是数据驱动的。 以下为书籍信息管理的数据关系&#xff1a;书籍和人物是 &#xff1a;一对多关系 要先分析出项目中所需要的数据, 然后设计数据库表. 书籍信息表 字段名字段类型字段说明idAutoField主键nameCharField书名 idname1西游记2三国演义…

SpringMVC中遇到的错误

SpringMVC中遇到的错误1.web.xml中配置SpringMVC核心类: DispatcherServlet 报错解决方案&#xff1a;添加Tomcat包2. not declaration can be found for element--------‘mvc:annotation-driven‘通配符的匹配很全面, 但无法找到元素 mvc:annotation-driven 的声明解决方案&a…

雅思经验(9)之小作文常用词汇总结

写作&#xff1a;关于趋势的上升和下降在小作文中&#xff0c;真的是非常常见的&#xff0c;所以还是要积累一下。下面给出了很多词&#xff0c;但是在雅思写作中并不是词越丰富&#xff0c;分数就越高的。雅思写作强调的是准确性&#xff1a;在合适的地方用合适的词和句法。不…

Python+Go实践(电商架构三)

文章目录服务发现集成consul负载均衡负载均衡算法实现配置中心nacos服务发现 我们之前的架构是通过ipport来调用的python的API&#xff0c;这样做的弊端是 如果新加一个服务&#xff0c;就要到某个服务改web&#xff08;go&#xff09;层的调用代码&#xff0c;配置IP/Port并发…

8年软件测试工程师经验感悟

不知不觉在软件测试行业&#xff0c;野蛮生长了8年之久。这一路上拥有了非常多的感受。有迷茫&#xff0c;有踩过坑&#xff0c;有付出有收获&#xff0c; 有坚持&#xff01; 我一直都在软件测试行业奋战&#xff0c; 毕业时一起入职的好友已经公司内部转岗&#xff0c;去选择…

理论七:为何说要多用组合少用继承?如何决定该用组合还是继承?

在面向对象编程中、有一条非常经典的设计原则&#xff0c;那就是&#xff1a;组合优于继承&#xff0c;多用组合少用继承。为什么不推荐使用继承&#xff1f;组合相比继承有哪些优势&#xff1f;如何判断该用组合还是继承&#xff1f;今天,我们就围绕着这三个问题&#xff0c;来…

Windows中安装Docker Desktop 4.16.3(当前最新版本)

前言 docker是一个用Go语言实现的开源项目&#xff0c;它可以很方便的创建和使用容器&#xff0c;docker将程序以及程序所有的依赖都打包到docker container&#xff0c;这样程序可以在任何环境都会有相同的表现&#xff0c;这里程序运行的依赖也就是容器类似集装箱&#xff0…

用于超大图像的训练策略:Patch Gradient Descent

前言 本文旨在计算和内存限制的情况下&#xff0c;解决在大规模图像上训练现有CNN 架构的问题。提出PatchGD&#xff0c;它基于这样的假设&#xff1a;与其一次对整个图像执行基于梯度的更新&#xff0c;不如一次只对图像的一小部分执行模型更新&#xff0c;确保其中的大部分是…

scscanner:一款功能强大的大规模状态码扫描工具

关于scscanner scscanner是一款功能强大的大规模状态码扫描工具&#xff0c;该工具可以帮助广大研究人员从一个URL列表文件中批量读取目标网站的状态码响应信息。除此之外&#xff0c;该工具还可以过滤出指定的状态码&#xff0c;并将结果存储到一个文件中以供后续深入分析使用…

Idea软件——Debug使用方法

Idea软件——Debug 1 Debug概述 Debug:是供程序员使用的程序测试工具&#xff0c;它可以用于查看程序和执行流程&#xff0c;也可以用于追踪程序执行过程来调试程序 1.2 Debug操作流程 Debug调试&#xff1a;又叫断点调试&#xff0c;断点其实是一个标记&#xff0c;告诉从何看…

实战项目-用户评论数据情绪分析

目录1、基于词典的方法2、基于词袋或 Word2Vec 的方法2.1 词袋模型2.2 Word2Vec3、案例&#xff1a;用户评论情绪分析3.1 数据读取3.2 语料库分词处理3.3 Word2Vec 处理3.4 训练情绪分类模型3.5 对评论数据进行情绪判断目的&#xff1a;去判断一段文本、评论的情绪偏向在这里&a…

九龙证券|一夜暴跌36%,美股走势分化,标普指数创近2月最差周度表现

当地时间2月10日&#xff0c;美股三大指数收盘涨跌纷歧。道指涨0.5%&#xff0c;标普500指数涨0.22%&#xff0c;纳指跌0.61%。 受国际油价明显上升影响&#xff0c;动力板块领涨&#xff0c;埃克森美孚、康菲石油涨超4%。大型科技股走低&#xff0c;特斯拉、英伟达跌约5%。热门…

[ 系统安全篇 ] window 命令禁用用户及解禁方法

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

MC0108白给-MC0109新河妇荡杯

MC0108白给 小码哥和小码妹在玩一个游戏&#xff0c;初始小码哥拥有 x的金钱&#xff0c;小码妹拥有 y的金钱。 虽然他们不在同一个队伍中&#xff0c;但他们仍然可以通过游戏的货币系统进行交易&#xff0c;通过互相帮助以达到共赢的目的。具体来说&#xff0c;在每一回合&a…

3.JUC【Java面试第三季】

3.JUC【Java面试第三季】前言推荐3.JUC06_闲聊AQS面试1.题目说明07_可重入锁理论2.可重入锁说明“可重入锁”这四个字分开来解释可重入锁的种类08_可重入锁的代码验证-上09_可重入锁的代码验证-下3.LockSupport10_LockSupport是什么LockSupport是什么11_waitNotify限制线程等待…