PyQt基础的综合示例

在这个综合示例中,我们将结合前面所学的内容,创建一个简单的 PyQt 应用程序,该程序具有以下功能:

  1. GUI 界面
  2. 数据库操作
  3. 网络通信
python 复制代码
from PyQt5.QtWidgets import QApplication, QPushButton, QVBoxLayout, QWidget
from PyQt5.QtSql import QSqlDatabase, QSqlQuery
from PyQt5.QtNetwork import QTcpSocket
from PyQt5.QtCore import QIODevice

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

def execute_query():
    query = QSqlQuery()
    query.exec_("CREATE TABLE IF NOT EXISTS people (id INTEGER PRIMARY KEY, name TEXT)")
    query.exec_("INSERT INTO people (name) VALUES ('John')")

def tcp_client():
    socket = QTcpSocket()
    socket.connectToHost("localhost", 8080)
    if socket.waitForConnected():
        socket.write(b"Hello, Server")
        if socket.waitForReadyRead():
            print("Received:", socket.readAll().data().decode())
        socket.close()

app = QApplication([])

window = QWidget()
layout = QVBoxLayout()

button_db = QPushButton('Connect to Database')
button_db.clicked.connect(connect_to_database)
layout.addWidget(button_db)

button_query = QPushButton('Execute Query')
button_query.clicked.connect(execute_query)
layout.addWidget(button_query)

button_network = QPushButton('Network Request')
button_network.clicked.connect(tcp_client)
layout.addWidget(button_network)

window.setLayout(layout)
window.show()

app.exec_()

这个示例程序创建了一个具有三个按钮的简单 GUI 界面。每个按钮都连接到一个槽函数,这些槽函数分别执行数据库连接、数据库查询和网络请求。

希望这个综合示例能帮助你更好地理解如何使用 PyQt 进行实际开发!

相关推荐
掘金者阿豪38 分钟前
关系数据库迁移的“暗礁”:金仓数据库如何规避数据完整性与一致性风险
后端
ServBay1 小时前
一个下午,一台电脑,终结你 90% 的 Symfony 重复劳动
后端·php·symfony
sino爱学习1 小时前
高性能线程池实践:Dubbo EagerThreadPool 设计与应用
java·后端
颜酱1 小时前
从二叉树到衍生结构:5种高频树结构原理+解析
javascript·后端·算法
掘金者阿豪1 小时前
UUID的隐形成本:一个让数据库“慢下来”的陷阱
后端
用户084465256371 小时前
Docker 部署 MongoDB Atlas 到服务端
后端
Anita_Sun2 小时前
一看就懂的 Haskell 教程 - 类型推断机制
后端·haskell
Anita_Sun2 小时前
一看就懂的 Haskell 教程 - 类型签名
后端·haskell
七八星天2 小时前
C#代码设计与设计模式
后端
砍材农夫3 小时前
threadlocal
后端