Python PyQt

Python PyQt

Python PyQt

PyQt 是一个强大的 Python 库,用于创建图形用户界面(GUI),可以用来代替 Python 内置的 Tkinter。

PyQt 是 Qt 框架的 Python 绑定,广泛应用于桌面应用程序开发。

Qt 是一个跨平台的 C++ 应用程序开发框架。

PyQt 允许 Python 开发者利用 Qt 库创建功能强大的 GUI 应用程序。

PyQt 有以下几个主要版本:

PyQt4:基于 Qt4 的绑定

PyQt5:基 于Qt5 的绑定

PyQt6:基于 Qt6 的绑定(最新版本)

安装 PyQt

使用 pip 安装 PyQt5:

# 安装PyQt5

pip install PyQt5

# 安装Qt设计师和其他工具(可选)

pip install PyQt5-tools

第一个 PyQt 程序

创建简单窗口

以下是一个最基本的 PyQt 程序,创建一个空白窗口:

实例

from PyQt5.QtWidgets import QApplication, QWidget

# 创建应用实例

app = QApplication([])

# 创建主窗口

window = QWidget()

window.setWindowTitle("我的第一个 PyQt 程序")

window.setGeometry(100, 100, 400, 300) # (x, y, width, height)

# 显示窗口

window.show()

# 运行应用

app.exec_()

代码解析

QApplication:管理 GUI 应用程序的控制流和主设置。

QWidget:最基本的窗口类,所有 UI 组件都继承自它。

setWindowTitle():设置窗口标题。

setGeometry():设置窗口位置和大小。

show():显示窗口。

app.exec_():启动事件循环,等待用户交互。

一个典型的PyQt应用程序包含以下部分:

QApplication对象:每个PyQt应用程序都需要有一个QApplication实例

窗口和控件:用户界面组件

事件循环:处理用户输入和系统事件的循环

事件处理器:响应事件的函数或方法

实例

import sys

from PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton

class MainWindow(QMainWindow):

def __init__(self):

super().__init__()

# 设置窗口标题和大小

self.setWindowTitle("我的第一个PyQt应用")

self.setGeometry(100, 100, 400, 300) # x, y, width, height

# 创建按钮

self.button = QPushButton("点击我", self)

self.button.setGeometry(150, 150, 100, 30)

self.button.clicked.connect(self.button_clicked)

def button_clicked(self):

print("按钮被点击了!")

if __name__ == "__main__":

app = QApplication(sys.argv)

window = MainWindow()

window.show()

sys.exit(app.exec_())

常用 PyQt 组件

按钮(QPushButton)

实例

from PyQt5.QtWidgets import QPushButton

button = QPushButton("点击我", window)

button.move(150, 150) # 设置按钮位置

标签(QLabel)

实例

from PyQt5.QtWidgets import QLabel

label = QLabel("Hello PyQt!", window)

label.move(100, 100)

文本框(QLineEdit)

实例

from PyQt5.QtWidgets import QLineEdit

textbox = QLineEdit(window)

textbox.move(100, 50)

更多常用组件内容参考:https://www.runoob.com/python3/python-pyqt-widgets.html

布局管理(QVBoxLayout)

使用布局管理器可以自动调整组件位置:

实例

from PyQt5.QtWidgets import QVBoxLayout, QLabel, QPushButton

layout = QVBoxLayout()

layout.addWidget(QLabel("用户名"))

layout.addWidget(QLineEdit())

layout.addWidget(QPushButton("登录"))

window.setLayout(layout)

更多布局管理内容参考:https://www.runoob.com/python3/python-pyqt-layout.html

信号与槽机制

PyQt 使用信号(Signal)和槽(Slot)机制处理事件。

PyQt 的信号和槽机制是用于对象之间通信的核心机制。

信号(Signal): 当特定事件发生时发出的通知

槽(Slot): 响应信号的函数或方法

实例

from PyQt5.QtWidgets import QPushButton

def on_button_click():

print("按钮被点击了!")

button = QPushButton("点击我", window)

button.clicked.connect(on_button_click) # 连接信号和槽

自定义信号

实例

from PyQt5.QtCore import pyqtSignal, QObject

class MyEmitter(QObject):

my_signal = pyqtSignal(str) # 定义一个信号

emitter = MyEmitter()

emitter.my_signal.connect(lambda x: print(f"收到信号: {x}"))

emitter.my_signal.emit("Hello") # 触发信号

更多布局管理内容参考:https://www.runoob.com/python3/python-pyqt-signals-and-slots.html

使用 Qt Designer

Qt Designer 是一个可视化设计工具,可以拖放组件来设计界面:

启动 Designer (通常在 Python 安装目录的 Lib\site-packages\qt5_applications\Qt\bin 下)

设计界面并保存为 .ui 文件

将 .ui 文件转换为 Python 代码:

pyuic5 input.ui -o output.py

在代码中使用生成的界面:

实例

from PyQt5 import uic

# 加载UI文件

Form, Window = uic.loadUiType("output.ui")

# 使用UI

app = QApplication(sys.argv)

window = Window()

form = Form()

form.setupUi(window)

window.show()

sys.exit(app.exec_())

实战:简单的记事本应用

界面设计

实例

import sys

from PyQt5.QtWidgets import (QApplication, QMainWindow, QTextEdit,

QAction, QFileDialog, QMessageBox)

class Notepad(QMainWindow):

def __init__(self):

super().__init__()

self.initUI()

def initUI(self):

self.text_edit = QTextEdit(self)

self.setCentralWidget(self.text_edit)

self.create_actions()

self.create_menus()

self.setWindowTitle('简易记事本')

self.setGeometry(100, 100, 800, 600)

def create_actions(self):

# 文件菜单动作

self.new_action = QAction('新建', self)

self.new_action.setShortcut('Ctrl+N')

self.new_action.triggered.connect(self.new_file)

self.open_action = QAction('打开', self)

self.open_action.setShortcut('Ctrl+O')

self.open_action.triggered.connect(self.open_file)

self.save_action = QAction('保存', self)

self.save_action.setShortcut('Ctrl+S')

self.save_action.triggered.connect(self.save_file)

self.exit_action = QAction('退出', self)

self.exit_action.setShortcut('Ctrl+Q')

self.exit_action.triggered.connect(self.close)

# 编辑菜单动作

self.copy_action = QAction('复制', self)

self.copy_action.setShortcut('Ctrl+C')

self.copy_action.triggered.connect(self.text_edit.copy)

self.paste_action = QAction('粘贴', self)

self.paste_action.setShortcut('Ctrl+V')

self.paste_action.triggered.connect(self.text_edit.paste)

self.cut_action = QAction('剪切', self)

self.cut_action.setShortcut('Ctrl+X')

self.cut_action.triggered.connect(self.text_edit.cut)

def create_menus(self):

menubar = self.menuBar()

# 文件菜单

file_menu = menubar.addMenu('文件')

file_menu.addAction(self.new_action)

file_menu.addAction(self.open_action)

file_menu.addAction(self.save_action)

file_menu.addSeparator()

file_menu.addAction(self.exit_action)

# 编辑菜单

edit_menu = menubar.addMenu('编辑')

edit_menu.addAction(self.copy_action)

edit_menu.addAction(self.paste_action)

edit_menu.addAction(self.cut_action)

def new_file(self):

self.text_edit.clear()

def open_file(self):

filename, _ = QFileDialog.getOpenFileName(self, '打开文件')

if filename:

try:

with open(filename, 'r') as f:

self.text_edit.setText(f.read())

except Exception as e:

QMessageBox.warning(self, '错误', f'无法打开文件: {e}')

def save_file(self):

filename, _ = QFileDialog.getSaveFileName(self, '保存文件')

if filename:

try:

with open(filename, 'w') as f:

f.write(self.text_edit.toPlainText())

except Exception as e:

QMessageBox.warning(self, '错误', f'无法保存文件: {e}')

if __name__ == '__main__':

app = QApplication(sys.argv)

notepad = Notepad()

notepad.show()

sys.exit(app.exec_())

PyQt5 核心组件

大多数组件位于 PyQt5.QtWidgets。

高级功能(如多媒体、网络)可能需要其他模块(如 QtCore, QtGui, QtNetwork 等)。

QListView/QTableView/QTreeView 需要搭配数据模型(如 QStandardItemModel)使用,灵活性更高。

其他安装扩展:

pip install PyQtWebEngine # 网页支持

pip install PyQtChart # 图表支持

组件类别组件名称所在模块说明基础窗口组件QWidgetQtWidgets所有用户界面对象的基类,可作为空白窗口或容器QMainWindowQtWidgets主窗口框架,包含菜单栏、工具栏、状态栏等QDialogQtWidgets对话框基类,用于弹出窗口布局管理QVBoxLayoutQtWidgets垂直布局管理器QHBoxLayoutQtWidgets水平布局管理器QGridLayoutQtWidgets网格布局管理器QFormLayoutQtWidgets表单布局管理器(标签+输入框对)按钮类QPushButtonQtWidgets普通按钮QRadioButtonQtWidgets单选按钮QCheckBoxQtWidgets复选框QToolButtonQtWidgets工具栏按钮(可带图标)输入控件QLineEditQtWidgets单行文本输入框QTextEditQtWidgets多行富文本编辑器(支持HTML)QPlainTextEditQtWidgets多行纯文本编辑器QSpinBoxQtWidgets数字调节框(整数)QDoubleSpinBoxQtWidgets数字调节框(浮点数)QComboBoxQtWidgets下拉选择框QDateEditQtWidgets日期选择框QTimeEditQtWidgets时间选择框QDateTimeEditQtWidgets日期时间选择框QSliderQtWidgets滑动条(水平/垂直)QDialQtWidgets圆形旋钮控件显示控件QLabelQtWidgets文本/图片标签QLCDNumberQtWidgetsLCD数字显示屏QProgressBarQtWidgets进度条QStatusBarQtWidgets状态栏(通常用于QMainWindow)容器类QGroupBoxQtWidgets分组框(带标题的容器)QTabWidgetQtWidgets标签页容器QStackedWidgetQtWidgets堆叠容器(每次显示一个子控件)QScrollAreaQtWidgets滚动区域容器QMdiAreaQtWidgetsMDI(多文档界面)区域列表/表格/树QListWidgetQtWidgets列表控件(含项管理)QTreeWidgetQtWidgets树形控件QTableWidgetQtWidgets表格控件QListViewQtWidgets列表视图(需搭配数据模型)QTableViewQtWidgets表格视图(需搭配数据模型)QTreeViewQtWidgets树形视图(需搭配数据模型)菜单/工具栏QMenuBarQtWidgets菜单栏QMenuQtWidgets菜单(可包含子菜单和动作)QToolBarQtWidgets工具栏QActionQtWidgets动作(用于菜单项、工具栏按钮等)对话框QFileDialogQtWidgets文件选择对话框QColorDialogQtWidgets颜色选择对话框QFontDialogQtWidgets字体选择对话框QInputDialogQtWidgets输入对话框(文本、数字等)QMessageBoxQtWidgets消息提示框(警告、错误、询问等)图形视图QGraphicsViewQtWidgets图形视图框架(用于2D图形)QGraphicsSceneQtWidgets图形场景(配合QGraphicsView使用)其他功能组件QCalendarWidgetQtWidgets日历控件QSplashScreenQtWidgets启动画面QSystemTrayIconQtWidgets系统托盘图标QWebEngineViewQtWebEngineWidgets网页浏览器组件(需单独安装PyQtWebEngine)

学习资源

PyQt 官网

PyQt5 官方文档

PyQt6 官方文档

Qt 官方文档

相关推荐

满汉全席
365bet体育线上

满汉全席

📅 07-21 👁️ 6990
81岁属什么生肖2025年 81岁是哪年出生的
365bet体育线上

81岁属什么生肖2025年 81岁是哪年出生的

📅 07-08 👁️ 6423
158cm是多少寸的箱子?
365bet体育线上

158cm是多少寸的箱子?

📅 07-02 👁️ 1332
手机pos机怎么使用刷卡
3654687

手机pos机怎么使用刷卡

📅 07-26 👁️ 1874