PyQt 高级部分学习 - 第五篇(最后一篇)

主题:数据库操作与综合示例

在这最后一篇高级部分的文章中,我们将探讨如何在 PyQt 应用中进行数据库操作,并给出一个综合示例。

数据库操作

PyQt 提供了 QtSql 模块来进行数据库操作。这里我们以 SQLite 为例。

连接数据库

python 复制代码
from PyQt5.QtSql import QSqlDatabase

def connect_to_database():
    db = QSqlDatabase.addDatabase("QSQLITE")
    db.setDatabaseName("mydatabase.db")

    if not db.open():
        print("Cannot open database")
        return False
    return True

执行 SQL 查询

python 复制代码
from PyQt5.QtSql import QSqlQuery

def execute_query():
    query = QSqlQuery()
    query.exec_("CREATE TABLE IF NOT EXISTS messages (id INTEGER PRIMARY KEY, text TEXT)")
    query.exec_("INSERT INTO messages (text) VALUES ('Hello, world!')")

综合示例:聊天应用

在之前的基础上,我们将添加一个功能:将聊天记录保存到数据库。

python 复制代码
from PyQt5.QtWidgets import QMainWindow, QTextEdit, QPushButton, QVBoxLayout, QWidget
from PyQt5.QtSql import QSqlDatabase, QSqlQuery
from PyQt5.QtCore import pyqtSignal

class ChatWindow(QMainWindow):
    def __init__(self):
        super().__init__()

        self.init_db()

        self.text_edit = QTextEdit()
        self.send_button = QPushButton("Send")
        self.send_button.clicked.connect(self.send_message)

        layout = QVBoxLayout()
        layout.addWidget(self.text_edit)
        layout.addWidget(self.send_button)

        container = QWidget()
        container.setLayout(layout)
        self.setCentralWidget(container)

    def init_db(self):
        self.db = QSqlDatabase.addDatabase("QSQLITE")
        self.db.setDatabaseName("chat.db")

        if not self.db.open():
            print("Cannot open database")
            return

        query = QSqlQuery()
        query.exec_("CREATE TABLE IF NOT EXISTS messages (id INTEGER PRIMARY KEY, text TEXT)")

    def send_message(self):
        text = self.text_edit.toPlainText()
        query = QSqlQuery()
        query.prepare("INSERT INTO messages (text) VALUES (:text)")
        query.bindValue(":text", text)
        query.exec_()

这样,我们的聊天应用就可以将聊天记录保存到 SQLite 数据库中了。

这便是高级部分的最后一篇文章,希望这些内容能帮助你深入了解 PyQt 的高级功能。感谢你的阅读!

相关推荐
李日灐6 小时前
C++进阶必备:红黑树从 0 到 1: 手撕底层,带你搞懂平衡二叉树的平衡逻辑与黑高检验
开发语言·数据结构·c++·后端·面试·红黑树·自平衡二叉搜索树
qq_297574677 小时前
【实战】POI 实现 Excel 多级表头导出(含合并单元格完整方案)
java·spring boot·后端·excel
郝学胜-神的一滴7 小时前
超越Spring的Summer(一): PackageScanner 类实现原理详解
java·服务器·开发语言·后端·spring·软件构建
Tony Bai7 小时前
“Go 2,请不要发生!”:如果 Go 变成了“缝合怪”,你还会爱它吗?
开发语言·后端·golang
Victor3568 小时前
Hibernate(91)如何在数据库回归测试中使用Hibernate?
后端
Victor3568 小时前
MongoDB(1)什么是MongoDB?
后端
Victor35614 小时前
https://editor.csdn.net/md/?articleId=139321571&spm=1011.2415.3001.9698
后端
Victor35614 小时前
Hibernate(89)如何在压力测试中使用Hibernate?
后端
灰子学技术16 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
Gogo81617 小时前
BigInt 与 Number 的爱恨情仇,为何大佬都劝你“能用 Number 就别用 BigInt”?
后端