手把手教你开发Python桌面应用-PyQt6图书管理系统-图书信息修改实现

锋哥原创的PyQt6图书管理系统视频教程:

PyQt6图书管理系统视频教程 Python桌面开发 Python入门级项目实战 (无废话版) 火爆连载更新中~_哔哩哔哩_bilibiliPyQt6图书管理系统视频教程 Python桌面开发 Python入门级项目实战 (无废话版) 火爆连载更新中~共计24条视频,包括:PyQt6图书管理系统视频教程 Python桌面开发 Python入门级项目实战 (无废话版) 火爆连载更新中~、第2讲 登录功能UI设计实现、第3讲 数据库操作工具包dbUtil.py封装等,UP主更多精彩视频,请关注UP账号。icon-default.png?t=N7T8https://www.bilibili.com/video/BV18t4y1R7Qp/首先表单操作界面,我们需要做一些处理,编号输入框设置只读,背景色灰色,默认的作者性别,我们可以设置成男,以及图书类别数据需要初始化下。

# 设置默认选中self.manRadio.setChecked(True)

初始化下拉框数据

    def initBookTypeListComboBox(self):"""初始化下拉框数据:return:"""bookTypeList = bookTypeDao.list("")  # 获取所有图书类别信息self.s_bookTypeComboBox.addItem("请选择图书类别...", -1)self.bookTypeComboBox.addItem("请选择图书类别...", -1)for bookType in bookTypeList:self.bookTypeComboBox.addItem(bookType[1], bookType[0])self.s_bookTypeComboBox.addItem(bookType[1], bookType[0])

编号输入框设置只读,以及背景色改成灰色

self.idInput.setReadOnly(True)self.idInput.setStyleSheet("background-color:gray")

接下来是行点击事件,点击行,获取行数据,初始化表单

先定义初始化表单方法initForm

    def initForm(self, index: QModelIndex):"""初始化Form:param index::return:"""rowIndex = index.row()  # 获取行索引self.idInput.setText(self.bookTable.item(rowIndex, 0).text())  # 设置编号self.bookNameInput.setText(self.bookTable.item(rowIndex, 1).text())  # 设置图书名称self.authorInput.setText(self.bookTable.item(rowIndex, 2).text())  # 设置图书作者self.bookTypeComboBox.setCurrentText(self.bookTable.item(rowIndex, 3).text())  # 设置图书类别if self.bookTable.item(rowIndex, 4).text() == '男':  # 设置性别self.manRadio.setChecked(True)else:self.femaleRadio.setChecked(True)self.priceInput.setText(self.bookTable.item(rowIndex, 5).text())  # 设置图书价格self.bookDescInput.setPlainText(self.bookTable.item(rowIndex, 6).text())  # 设置图书类别描述

然后是行点击事件绑定

# 行点击事件self.bookTable.clicked.connect(self.initForm)

运行测试:

我们具体执行修改操作,bookDao里编写update方法:

def update(book: Book):"""图书修改:param book: 图书实体:return: 返回执行的记录条数"""con = Nonetry:con = dbUtil.getCon()cursor = con.cursor()cursor.execute(f"update t_book set bookName='{book.bookName}',author='{book.author}',sex='{book.sex}',price={book.price},bookTypeId={book.bookTypeId},bookDesc='{book.bookDesc}' where id={book.id}")return cursor.rowcountexcept Exception as e:print(e)con.rollback()return 0finally:dbUtil.closeCon(con)

更新表单的时候,我们向dao层update传递的book实体对象参数,构造的时候,是所有参数都包含,所以我们要再Book实体类里重新定义一个重载构造方法:

    @staticmethoddef my_constructor2(id, bookName, author, sex, price, bookTypeId, bookDesc):obj = Book(bookName, author, bookTypeId)obj.id = idobj.sex = sexobj.price = priceobj.bookDesc = bookDescreturn obj

修改成功后,还需要重置表单,所以写编写一个重置表单的方式resetForm

    def resetForm(self):"""重置表单:return:"""self.idInput.setText("")self.bookNameInput.setText("")self.authorInput.setText("")self.bookTypeComboBox.setCurrentIndex(0)self.manRadio.setChecked(True)self.priceInput.setText("")self.bookDescInput.setPlainText("")

接下来,bookManage.py的Ui_Form里,加下update方法:

    def update(self):"""更新表单:return:"""id = self.idInput.text()if id.strip() == "":QMessageBox.information(None, '系统提示', '请选中您需要编辑的那行数据!')returnbookName = self.bookNameInput.text()if bookName.strip() == "":QMessageBox.information(None, '系统提示', '请输入图书名称!')returnsex = "男"if self.femaleRadio.isChecked():sex = "女"price = self.priceInput.text()if price.strip() == "":QMessageBox.information(None, '系统提示', '请输入图书价格!')returnauthor = self.authorInput.text()if author.strip() == "":QMessageBox.information(None, '系统提示', '请输入图书作者!')returnbookTypeId = self.bookTypeComboBox.currentData()bookDesc = self.bookDescInput.toPlainText();book = Book.my_constructor2(id, bookName, author, sex, price, bookTypeId, bookDesc)if bookDao.update(book) > 0:QMessageBox.information(None, '系统提示', '修改成功!')self.initTable()self.resetForm()else:QMessageBox.warning(None, '系统提示', '修改失败!')

编辑按钮绑定点击事件

# 编辑按钮点击事件绑定self.modifyBtn.clicked.connect(self.update)

运行测试:

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

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

相关文章

从互联网的公开信息中,找到属于你的赚钱思路

一、教程描述 人们在互联网上的每一次搜索、每一次关注、每一次点击、每一次点赞、每一次评论、每一次付费,都生成了大量的数据和信息,暴露着人们的真实想法、欲望、恐惧和需求。这些数据和信息,就是我们身边的一座“金矿”,而大…

项目中的一些疑难杂记

疑难杂记 1. 关于正则表达式对象的匹配状态问题发现查找原因解决方法done 喜大普奔 1. 关于正则表达式对象的匹配状态 问题发现 因页面中多个函数使用到同一个正则表达式,想着定义个变量 export 出去然后在对应的函数中引用,一切正常中… 直到有一天&a…

1【算法】——最大子数组问题(maximum subarray)

一.问题描述 假如我们有一个数组,数组中的元素有正数和负数,如何在数组中找到一段连续的子数组,使得子数组各个元素之和最大。 二.问题分析 分治法求解: 初始状态: low0;highA.length-1;mid&am…

CGAL::2D Arrangements-2

2.3.2 遍历Arrangement Halfedge Arrangement的一条Halfedge是和一个 X_monotone_curve_2对象绑定,这个curve可以通过e->curve()获取。 e->source()得到源点,e->target()得到目标点,e->twin()得到半边的对边, 第个半…

最新的 Ivanti SSRF 零日漏洞正在被大规模利用

Bleeping Computer 网站消息,安全研究员发现 Ivanti Connect Secure 和 Ivanti Policy Secure 服务器端请求伪造 (SSRF) 漏洞(CVE-2024-21893 )正在被多个威胁攻击者大规模利用。 2024 年 1 月 31 日,Ivanti 首次就网关 SAML 组件…

Java设计模式——策略

前言 策略模式是平时Java开发中常用的一种,虽然已有很多讲解设计模式的文章,但是这里还是写篇文章来从自己理解的角度讲解一下。 使用场景 我们不妨进行场景假设,要对我们的软件进行授权管理:在启动我们的软件之前先要校验是否…

万维网的文档

目录 1 万维网的文档 动态万维网文档 CGI CGI 网关程序 活动万维网文档 用 Java 语言创建活动文档 1 万维网的文档 分为: 静态万维网文档。内容不会改变。简单。(html、xml、css) 动态万维网文档。文档的内容由应用程序动态创建。 活动万维网文档。由浏览器端…

SpringBoot3整合Knife4j

前置&#xff1a; 官网&#xff1a;快速开始 | Knife4j gitee&#xff1a;swagger-bootstrap-ui-demo: knife4j 以及swagger-bootstrap-ui 集成框架示例项目 - Gitee.com 1.依赖引入&#xff1a; ps&#xff1a;json处理需要引入相关包 <dependency><groupId>c…

作业 2.12

封装strlen #include <stdio.h> #include <string.h> int main(int argc, const char *argv[]) { char arr[30]; gets(arr); char *paarr; int i0; int sum0; for(i0;arr[i]!\0;i) { sum; } printf("%d",s…

基于语义解析的知识图谱问答系统

目录 前言1 背景介绍2 语义解析的核心技术2.1 自然语言处理&#xff08;NLP&#xff09;2.2 语义表示学习2.3 实体关系抽取 3 语义解析的基本步骤3.1 短语检测3.2 资源映射3.3 语义组合3.4 逻辑表达式生成 4 处理与知识图谱无关的问句4.1 Bridging技术4.2 确定谓词4.3 Paraphra…

【新书推荐】7.4节 寄存器间接和相对寻址方式

本节内容&#xff1a;当指令操作数为内存操作数&#xff0c;且内存操作数的地址使用指针寄存器表示时&#xff0c;称为寄存器间接寻址方式。 ■寄存器间接寻址方式&#xff1a;在地址表达式中&#xff0c;只能使用BX、SI、DI、BP四个指针寄存器用来寻址。 7.4.1 寄存器间接寻…

猫头虎分享已解决Bug || API限制超额(API Rate Limiting):RateLimitExceeded, APILimitReached

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

mysql入门到精通006-基础篇-多表查询

1、多表关系介绍 1.1 概念 项目开发中&#xff0c;在进行数据库表结构设计时&#xff0c;会根据业务需求和业务模块之间的关系&#xff0c;分析并设计表结构&#xff0c;由于业务之间相互关联&#xff0c;所以各个表结构之间也存在各种联系&#xff0c;基本上分为3种&#xf…

MongoDB聚合:$unwind

使用$unwind可以对输入文档数组字段进行结构&#xff0c;为每个数组元素输出一个文档&#xff0c;并且每个输出文档都是输入文档数组字段的值。相当于将内嵌的数组文档提升到了顶层。 语法 可以通过字段路径或文档操作符来展开数组字段。 通过字段操作符展开 可以将数组字段…

如何用 docker 部署程序?

如何用 docker 部署程序&#xff1f;这个问题有点笼统。 如果是MySQL、Redis这些&#xff0c;只需要拉取镜像&#xff0c;然后设置必要的配置&#xff0c;最终创建并运行实例即可。 如果你的应用是一个Java应用程序&#xff0c;使用Docker来部署它会涉及到Java特有的一些考虑…

c# Config 配置文件帮助类

public class ConfigHelper { #region 获取指定目录 AppSettings 配置文件值 /// <summary> /// 获取指定目录 AppSettings 配置文件值 /// </summary> /// <param name"key"></param> /// <…

LeetCode.144. 二叉树的前序遍历

题目 144. 二叉树的前序遍历 分析 这道题目是比较基础的题目&#xff0c;我们首先要知道二叉树的前序遍历是什么&#xff1f; 就是【根 左 右】 的顺序&#xff0c;然后利用递归的思想&#xff0c;就可以得到这道题的答案&#xff0c;任何的递归都可以采用 栈 的结构来实现…

片上网络NoC(1)——导论

一、多核时代的出现 自从20世纪90年代末引入多核芯片研究以来&#xff0c;片上网络已经成为一个重要且不断发展的研究领域。随着计算核心数量的不断增加&#xff0c;多核处理器被广泛应用在高端服务器、智能手机&#xff0c;甚至物联网&#xff08;Internet of Things,IoT)网关…

Microsoft Word 清除格式

Microsoft Word 清除格式 References 选择文本&#xff0c;用快捷键 Ctrl Shift N&#xff0c;可以快速清除格式。 选择文本&#xff0c;清除格式。 References [1] Yongqiang Cheng, https://yongqiang.blog.csdn.net/

System V信号量

1.信号量 信号量本质上就是一把计数器(资源计数器) 表示资源数目的计数器,每一个执行流想访问公共资源内部的某一份资源&#xff0c;不应该让执行流先访问,而是先申请信号量资源,其实就是先对信号量计数器进行–操作,本质上,只要–成功&#xff0c;就完成了对资源的预订机制 如…