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 进行实际开发!

相关推荐
用户4822137167751 分钟前
C++——字符串常量、二维数组、函数与指针的深度应用(补)
后端
用户4822137167752 分钟前
C++——类型转换
后端
lichenyang45311 分钟前
mongoose(对象文档模型库)的使用
后端
用户48221371677513 分钟前
C++——继承进阶
后端
洛卡卡了37 分钟前
数据库加密方案实践:我们选的不是最完美,但是真的够用了。
数据库·后端·面试
Java中文社群37 分钟前
淘宝首位程序员离职,竟投身AI新公司做这事!
人工智能·后端·程序员
big_eleven39 分钟前
轻松掌握数据结构:二叉树
后端·算法·面试
big_eleven42 分钟前
轻松掌握数据结构:二叉查找树
后端·算法·面试
duration~1 小时前
SpringAI集成MCP
人工智能·后端·spring·ai
Java水解1 小时前
Java最新面试题(全网最全、最细、附答案)
java·后端·面试