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

news2024/11/24 16:25:31

锋哥原创的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 = None
    try:
        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.rowcount
    except Exception as e:
        print(e)
        con.rollback()
        return 0
    finally:
        dbUtil.closeCon(con)

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

    @staticmethod
    def my_constructor2(id, bookName, author, sex, price, bookTypeId, bookDesc):
        obj = Book(bookName, author, bookTypeId)
        obj.id = id
        obj.sex = sex
        obj.price = price
        obj.bookDesc = bookDesc
        return 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, '系统提示', '请选中您需要编辑的那行数据!')
            return
        bookName = self.bookNameInput.text()
        if bookName.strip() == "":
            QMessageBox.information(None, '系统提示', '请输入图书名称!')
            return
        sex = "男"
        if self.femaleRadio.isChecked():
            sex = "女"
        price = self.priceInput.text()
        if price.strip() == "":
            QMessageBox.information(None, '系统提示', '请输入图书价格!')
            return
        author = self.authorInput.text()
        if author.strip() == "":
            QMessageBox.information(None, '系统提示', '请输入图书作者!')
            return
        bookTypeId = 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.coloradmin.cn/o/1445501.html

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

相关文章

C++ //练习 5.19 编写一段程序,使用do while循环重复地执行下述任务:首先提示用户输入两个string对象,然后挑出较短的那个并输出它。

C Primer(第5版) 练习 5.19 练习 5.19 编写一段程序,使用do while循环重复地执行下述任务:首先提示用户输入两个string对象,然后挑出较短的那个并输出它。 环境:Linux Ubuntu(云服务器&#x…

CTFSHOW web 89-100

这边建议去我的gitbook或者github看观感更好(图片更完整) github:https://github.com/kakaandhanhan/cybersecurity_knowledge_book-gitbook.22kaka.fun gitbook:http://22kaka.fun 🏈 CTFSHOW PHP特性 (1)WEB 89 ①代码解释 <?php/* # -*- coding: utf-8 -*- # @…

第8讲个人中心页面搭建实现

个人中心页面搭建实现 <template><view class"user_center"><!-- 用户信息开始 --><view class"user_info_wrap"><!--获取头像--><button class"user_image"></button> <view class"user_n…

Java多线程:常见的锁策略

&#x1f451;专栏内容&#xff1a;Java⛪个人主页&#xff1a;子夜的星的主页&#x1f495;座右铭&#xff1a;前路未远&#xff0c;步履不停 目录 一、乐观锁 vs 悲观锁1、乐观锁2、悲观锁 二、重量级锁 vs 轻量级锁1、重量级锁2、轻量级锁3、理解用户态 vs 内核态 三、自旋锁…

LibreOffice Calc 取消首字母自动大写 (Capitalize first letter of every sentence)

LibreOffice Calc 取消首字母自动大写 [Capitalize first letter of every sentence] 1. Tools -> AutoCorrect Options2. AutoCorrect -> Options -> Capitalize first letter of every sentenceReferences 1. Tools -> AutoCorrect Options 2. AutoCorrect ->…

SpringCloud-高级篇(二十一)

前面解决了消息的可靠性、消息的延迟问题&#xff0c;下面研究一下消息的堆积的问题&#xff1a; &#xff08;1&#xff09;消息堆积问题 消息产生堆积&#xff0c;上限后&#xff0c;最早的消息成为死信&#xff0c;有消息被丢弃&#xff0c;这对安全性较高的业务中是不行的…

Uniapp真机调试:手机端访问电脑端的后端接口解决

Uniapp真机调试&#xff1a;手机端访问电脑端的后端接口解决 1、前置操作 HBuilderX -> 运行 -> 运行到手机或模拟器 -> 运行到Android App基座 少了什么根据提示点击下载即可 使用数据线连接手机和电脑 手机端&#xff1a;打开开发者模式 -> USB调试打开手机端&…

小白速成法:剖析一个Android项目以快速上手

这是一个基于Tasmota的设备、用MQTT协议来通信控制的安卓应用程序。支持ON/OFF命令插座和基本的RGB LED控制。 源码点击此处 只需要关注SmartController-main\app\src的代码 项目解压之后如图 只需要关注“app”文件夹里的东西即可&#xff0c;“gradle”是配置文件&#xf…

【前端web入门第五天】03 清除默认样式与外边距问题【附综合案例产品卡片与新闻列表】

文章目录: 1.清除默认样式 1.1清除内外边距1.2清除列表圆点(项目符号) 3.外边距问题-合并现象4.外边距问题–塌陷问题5.行内元素垂直内外边距6.圆角与盒子阴影 6.1圆角 6.2 盒子模型-阴影(拓展) 综合案例一 产品卡片 综合案例二 新闻列表 1.清除默认样式 在实际设计开发中,要…

Pandas深度解析GroupBy函数的妙用技巧【第75篇—GroupBy函数】

Pandas深度解析GroupBy函数的妙用技巧 数据处理和分析中&#xff0c;Pandas是一款非常强大的Python库&#xff0c;提供了丰富的数据结构和功能&#xff0c;使得数据分析变得更加简便高效。其中&#xff0c;GroupBy函数是Pandas中一个重要且常用的功能&#xff0c;通过它我们可…

第四节课[XTuner微调]作业

文章目录 前言作业基础作业-XTuner InternLM-Chat 个人小助手认知微调实践 前言 XTuner 做在第三节课LangChain作业之前&#xff0c;因为第三节课没想好找哪个领域&#xff0c;等第三节课作业做了一起部署。 作业 基础作业-XTuner InternLM-Chat 个人小助手认知微调实践 然…

Ps:直接从图层生成文件(图像资源)

通过Ps菜单&#xff1a;文件/导出/将图层导出到文件 Layers to Files命令&#xff0c;我们可以快速地将当前文档中的每个图层导出为同一类型、相同大小和选项的独立文件。 Photoshop 还提供了一个功能&#xff0c;可以基于文档中的图层或图层组的名称&#xff0c;自动生成指定大…

渗透专用虚拟机(公开版)

0x01 工具介绍 okfafu渗透虚拟机公开版。解压密码&#xff1a;Mrl64Miku&#xff0c;压缩包大小&#xff1a;15.5G&#xff0c;解压后大小&#xff1a;16.5G。安装的软件已分类并在桌面中体现&#xff0c;也可以使用everything进行查找。包含一些常用的渗透工具以及一些基本工…

opencv图像像素的读写操作

void QuickDemo::pixel_visit_demo(Mat & image) {int w image.cols;//宽度int h image.rows;//高度int dims image.channels();//通道数 图像为灰度dims等于一 图像为彩色时dims等于三 for (int row 0; row < h; row) {for (int col 0; col < w; col) {if…

RabbitMQ之五种消息模型

1、 环境准备 创建Virtual Hosts 虚拟主机&#xff1a;类似于mysql中的database。他们都是以“/”开头 设置权限 2. 五种消息模型 RabbitMQ提供了6种消息模型&#xff0c;但是第6种其实是RPC&#xff0c;并不是MQ&#xff0c;因此不予学习。那么也就剩下5种。 但是其实3、4…

【数学建模】【2024年】【第40届】【MCM/ICM】【E题 财产保险的可持续性】【解题思路】

一、题目 &#xff08;一&#xff09; 赛题原文 2024 ICM Problem E: Sustainability of Property Insurance Extreme-weather events are becoming a crisis for property owners and insurers. The world has endured “more than $1 trillion in damages from more than …

尚硅谷 Vue3+TypeScript 学习笔记(下)

目录 五、组件通信 5.1. 【props】 5.2. 【自定义事件】 5.3. 【mitt】 5.4.【v-model】 5.5.【$attrs】 5.6. 【$refs、$parent】 5.7. 【provide、inject】 5.8. 【pinia】 5.9. 【slot】 1. 默认插槽 2. 具名插槽 3. 作用域插槽 六、其它 API 6.1.【shallowR…

Python学习从0到1 day16 Python文件操作

2024新年快乐&#xff01;&#xff01;&#xff01; 今天是大年初三&#xff0c;祝大家万事胜意&#xff0c;一切都会好的&#xff0c;休息了一段时间&#xff0c;从今天开始继续学习~ ​​​​​​​——24.2.12 一、文件的编码 计算机只能识别0和1&#xff0c;那么我们丰富的…

Spring Boot 笔记 002 整合mybatis做数据库读取

概念 MyBatis 是一款优秀的持久层框架&#xff0c;它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO&#xff08;Plain Old Java Objec…

并发CPU伪共享及优化

目录 伪共享 解决 伪共享 缓存系统中是以缓存行&#xff08;cache line&#xff09;为单位存储的。缓存行是2的整数幂个连续字节&#xff0c;一般为32-256个字节。最常见的缓存行大小是64个字节。当多线程修改互相独立的变量时&#xff0c;如果这些变量共享同一个缓存行&am…