Python GUI项目实战(三)实现信息查询功能
off999 2024-12-25 14:47 43 浏览 0 评论
前言
在上一讲Python GUI项目实战(二)主窗体的界面设计与实现 我们实现了本项目主窗体界面的搭建,完成了左边栏的功能按钮、右边栏的查询界面和主体部分显示所有学生的概要信息,为了能够快速的找到具体的某个学生信息,我们需要实现学生信息的查询功能。本节我们将介绍如何实现单条件查询和多条件筛选,快速找到指定的某一个学生信息!
一、单条件查询
分析:
首先我们所有的学生信息存储在:all_student_list这个列表中,我们需要获取用户在输入框输入的内容也就是查询关键字,然后将符合条件的数据存储到一个新的list中query_result_list
1. 数据准备
新建一个存储查询结果的列表
self.query_result_list = []由于我们要实现通过输入学号来查询学生信息的功能,所以我们需要给输入框添加一个变量
self.var_sno = StringVar()在原有的构建学号输入框的Entry_sno中,添加参数textvariable = self.var_sno
2. 写一个查询的方法
我们需要写一个独立的方法get_query_result(),来实现获取查询结果;
def get_query_result(self):
# 准备查询条件:获取学号
query_condition = self.Entry_sno.get()
# 遍历List获取符合条件的学生信息
for item in self.all_student_list:
if query_condition in item[0]:
# 满足条件的学生
self.query_result_list.append(item)
# 把结果加载的TreeView中
self.load_treeview(self.query_result_list)3. 清空处理
每次调用load_treeciew()方法都会将列表中的数据存入Tree中,所以我们在使用函数load_treeview()方法之前,需要把当前TreeView中的内容清空,清空的方法如下:
for i in self.Tree.get_children():
self.Tree.delete(i)然后把条件捆绑到Button_query上
command = self.get_query_result于此同时,我们的query_result_list存储了每次查询的结果,每次查询前如果不对其清空,则每次查询结果都有上次的记录。所以我们每次查询操作前都要对query_result_list列表做清空处理:
self.query_result_list.clear()4. 实现显示全部数据的功能
实现显示全部学生信息的功能很简单,我们写一个独立的方法load_all_student(),我们可以把之前自动执行的函数添加进来就可以了
def load_all_student(self):
# 加载所有的学生信息到treeview
self.load_treeview(self.all_student_list)然后我们把load_all_student()函数捆绑到,Button_all这个按钮上即可,同样我们只需添加参数command = self.load_all_student即可。 至此我们便实现了单条件查询功能,通过输入学号点击查询按钮便可以在结果中查询到数据项,点击显示全部按钮便可显示全部的学生信息。
效果如下:
二、多条件组合查询
分析:
多条件查询的难点:如果有的条件没有填写,在手机查询条件的时候到底是否采集? 我们采用的方案是:无论是否填写,都采集数据。
主要判断逻辑为:
if sno in list and name in list and mobile in list and id in list因为,如果没有填写采集到的数据为空,"" in list不影响结果的判断。 那么如何把这些条件组合起来呢?一个条件我们上面用的是字符串,那么多个条件我们用列表即可。
1. 数据准备
在setup_UI()这个函数中,对每个Entry控件,添加textvariable变量
# 准备查询条件,去空格后往列表中添加数据
query_condition = []
query_condition.append(self.Entry_sno.get().strip()) #采集学号信息
query_condition.append(self.Entry_name.get().strip()) # 采集姓名信息
query_condition.append(self.Entry_mobile.get().strip()) # 采集手机号码信息
query_condition.append(self.Entry_id.get().strip()) # 采集身份证号码信息2. 修改遍历方法
因为我们现在的查询条件query_condition已经不是字符串了,所以对应的遍历方法就要做相应的修改,query_condition列表中的下标为0、1、2、3分别是学号、姓名、手机号、身份证号,对应的数据源中的单个数据列表的位置是0、1、4、7
# 遍历List获取符合条件的学生信息
for item in self.all_student_list:
if query_condition[0] in item[0] and query_condition[1] in item[1] and \
query_condition[2] in item[4] and query_condition[3] in item[7]:
# 满足条件的学生
self.query_result_list.append(item)3. 点击显示全部按钮后输入框清空
我们在获得查询结果后,点击了显示全部按钮,此时各个Entry框里的数值应当清空。所以在load_all_student函数中,将各个组件的数值清空,我们可以使用set()方法:
def load_all_student(self):
# 把所有条件文本框清空
self.var_sno.set("")
self.var_name.set("")
self.var_mobile.set("")
self.var_id.set("")
# 加载所有的学生信息到treeview
self.load_treeview(self.all_student_list)显示效果
最后
本节我们已经实现了学生信息的查询包括单条件查询和组合查询,但是我们还想点击指定条目查看学生具体的明细信息该怎么实现呢?下一节我们将介绍如何实现学生明细信息的查看,敬请期待吧~
小雨每篇文章都很认真的在写哦,由于个人水平有限难免会有一些错误,还请各位大神批评指正。有什么疑惑或者建议欢迎评论区留言,我会尽力解答,最后最好能转发、点赞支持一下~嘻嘻
相关推荐
- 无敌系统流小说(无敌系统流的小说)
-
《嫡女之花开富贵》作者:伊人睽睽简介祖父是镇国将军,贵不可言;外公是帝师,才名满天下;父母亲琴瑟和鸣,恩爱无双,无妾室插足;穿越为书香门第的嫡小姐,且无任何庶兄妹,慕兰音认为,她这一生,必将佳期如梦...
-
- 键盘上windows键是哪个键(电脑键盘上windows键是哪个)
-
一、台式机键盘。Windows键,简称“Winkey”或“Win键”,是在计算机键盘左下角Ctrl和Alt键之间的按键,台式机全尺寸键盘的主键盘区左下角和右下角各有一个,图案是MicrosoftWindows的视窗徽标。二、笔记...
-
2026-01-13 11:51 off999
-
- 桌面图标设置在哪打开(桌面图标从哪里调出)
-
1、首先来到电脑桌面,此时桌面没有任何图标,如下图所示。2、我们先右键单击任务栏,会出现工具栏,这时我们在下拉的选项里选择“快速启动”按钮。3、单击快速启动按钮后会出现如图所示情况,这时在电脑屏幕的左下方会显示很多快捷按钮,一般情况下单击快...
-
2026-01-13 10:51 off999
- windows如何进入启动项(怎么进入启动选项)
-
方法步骤如下:1.点击应用在Windows设置界面点击应用选项进入。2.选择启动在左侧分类中选择启动选项。3.点击开关点击软件后方的开关即可启动或关闭开机启动项。1、在Window的文件资...
- win11下载安装
-
一、允许安装软件1、首先点击左下角的开始按键,然后点击“settings”进入设置。2、然后点击设置中的“应用”选项。3、在点击左侧任务栏中的“应用和功能”。4、点击下拉栏,然后选择其中的“任何来源”...
- win7支持的最高配置(win7支持的最高配置是多少)
-
答案是支持win7的最高配置应该是i99900k加b365主板。 不过这套配置市面上价格偏高。这种机器比同等酷睿13代处理器的价格还要高至少一千元以上。而且就性能而言要超过i99900...
- 指令引用的内存不能为read(指令引用的0x0000000内存.该内存不能为read)
-
出现“指令引用内存不能为read”的错误可能有多种原因,包括软件冲突、驱动问题、内存质量问题等。以下是一些可能的解决方案:1.检查是否有软件冲突:尝试关闭可能冲突的软件,例如杀毒软件、优化软件等。2...
- hp1010打印机驱动程序(hp deskjet1010打印机驱动)
-
1.把光盘到电脑里然后打开光盘找到“setup.exe”双击运行。2.这里点击“不用了,谢谢,我喜欢CD安装”;下载的驱动也点这个。3.到这个一步有6个软件需要安装,不用点选直接下一步即可。4.同意服...
- 电脑黑屏怎么关机(电脑黑屏怎么关机不会伤硬盘)
-
开机按F8不动到高级选项出现在松手,选“最近一次的正确配置”回车修复,还不行按F8进入安全模式还原一下系统或重装系统(如果开机没反应,放一下电,重新插拔一下硬件,如果总是开不了机就检修一下去)。如果是...
- 应用程序无法启动0xc0000005
-
4、设备主板故障也会导致无信号,建议联系专业的维修人员上门检修。5、设备显卡手指边与手指边插槽接触不良,清理一下显卡的金手指边,重新插回去,重新固定住即可。应用程序错误0xc0000005解决方法如下...
- 移动硬盘分区方法详解(移动硬盘分区步骤)
-
1、进入管理页面将新买的移动硬盘插入计算机的USB接口,右击此电脑后选择管理。2、选择压缩卷在页面里选择“磁盘管理”,右击移动硬盘,选择“压缩卷”。3、输入压缩空间的大小输入压缩空间的大小,点击右下角...
- windows7副本不是正版影响使用吗
-
会经常弹出提示和安全警告,如果我们安装了一个非正版的windows系统,就会经常弹出此windows副本不是正版的提示,那么此windows副本不是正版有什么影响呢,其实除了视觉外,功能也会有影响。w...
-
- 100个有效qq号以及密码2025(2021最新qq号和密码大全)
-
有关QQ登记全国之最的数据目前并没有最新数据更新,最新的该项数据是截止于2019年12月的数据,接下来为大家带来QQ等级全国第一的用户的有关数据,仅供大家娱乐之用:截止2019年12月,全国qq等级第一名的名字叫做“小风波”,QQ等级高达1...
-
2026-01-13 05:51 off999
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
