PyQt5 超详细教程:基础与常用控件入门
是 PyQt5 入门教程序篇,涵盖安装配置、基础窗口结构及布局管理。内容详解了 QVBoxLayout、HBoxLayout 和 QGridLayout 的使用,并介绍了 QLabel、QPushButton、QLineEdit、QCheckBox 和 QComboBox 等常用控件的代码实现与事件处理。适合初学者快速掌握 PyQt5 桌面应用开发基础。

是 PyQt5 入门教程序篇,涵盖安装配置、基础窗口结构及布局管理。内容详解了 QVBoxLayout、HBoxLayout 和 QGridLayout 的使用,并介绍了 QLabel、QPushButton、QLineEdit、QCheckBox 和 QComboBox 等常用控件的代码实现与事件处理。适合初学者快速掌握 PyQt5 桌面应用开发基础。

PyQt5 是 Python 的图形用户界面 (GUI) 框架,它基于强大的 Qt 库。Qt 是一个跨平台的 C++ 框架,用于构建桌面应用程序。通过 PyQt5,我们可以用 Python 轻松构建跨平台的桌面应用程序,支持 Windows、macOS 和 Linux。
pip install PyQt5
pip list 查看是否安装了 PyQt5。接下来,我们将在 PyCharm 中创建一个简单的 PyQt5 应用程序,显示一个包含 'Hello, World!' 的窗口。
main.py。main.py 文件中,输入以下代码:import sys
from PyQt5.QtWidgets import QApplication, QLabel, QMainWindow
# 创建一个主窗口类,继承自 QMainWindow
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
# 调用父类 QMainWindow 的初始化方法
self.setWindowTitle("PyQt5 第一个窗口")
# 设置窗口标题
# 创建一个 QLabel 标签,并将其作为主窗口的中央控件
label = QLabel("Hello, World!", self)
self.setCentralWidget(label)
# 将标签作为窗口的中央控件
# 创建一个 PyQt5 应用程序对象
app = QApplication(sys.argv)
# 创建主窗口实例
window = MainWindow()
window.show()
# 显示窗口
# 进入应用程序的事件循环,保持应用程序运行,直到关闭窗口
sys.exit(app.exec_())
import sys
sys 是 Python 的内置模块,提供了一些与 Python 解释器进行交互的功能。在 PyQt5 中,sys.exit() 用来确保应用程序关闭时退出干净,不留任何后台进程。from PyQt5.QtWidgets import QApplication, QLabel, QMainWindow
QApplication:每个 PyQt5 程序必须有一个 QApplication 实例,它管理应用程序的控制流和设置。QMainWindow:这是 PyQt5 中的主窗口类,它是所有复杂窗口的基础。可以包含菜单栏、工具栏、状态栏、中央控件等。QLabel:这是一个简单的控件,用于显示文本。class MainWindow(QMainWindow):
MainWindow 的类,继承自 QMainWindow。通过继承 QMainWindow,我们可以自定义窗口的行为和外观。self.setWindowTitle("PyQt5 第一个窗口")
label = QLabel("Hello, World!", self)
QLabel 控件,显示文本 'Hello, World!'。self 参数:将标签关联到当前窗口(MainWindow),即将其设置为窗口的子控件。self.setCentralWidget(label)
label 为窗口的中央控件,中央控件是填充窗口中间区域的控件。app = QApplication(sys.argv)
QApplication 是 PyQt5 应用程序的基础,每个 PyQt5 应用程序都必须有一个 QApplication 实例,它管理整个应用程序的生命周期和事件处理。sys.argv:传递命令行参数,通常可以忽略。window.show()
sys.exit(app.exec_())
app.exec_() 开始应用程序的事件循环,保持应用程序的持续运行,直到用户关闭窗口。sys.exit() 确保应用程序正常退出。运行代码后,你将看到一个包含 'Hello, World!' 的窗口弹出。

pip list 命令检查是否安装。window.show(),没有调用该方法窗口将不会显示。在 PyQt5 中,窗口(window)是应用程序的核心部分。我们已经了解了如何创建一个简单的 QMainWindow,并在其中显示一些基本内容,比如文本标签 (QLabel)。现在,我们将进一步了解 PyQt5 中的 布局管理,并学习如何合理地组织多个控件,使界面更具交互性和美观性。
QWidget:是 PyQt5 中的所有控件(如按钮、标签、文本框等)的基类。任何可视化控件基本上都可以继承自 QWidget。它也是最基础的窗口控件,可以用来创建简单的窗口。QMainWindow:是一个高级窗口控件,继承自 QWidget,但是它具有更多的功能,比如菜单栏、工具栏、状态栏等。你可以把 QMainWindow 理解为一个'带更多功能的高级窗口'。在开发 GUI 应用程序时,如何排列和管理窗口中的控件至关重要。PyQt5 提供了几个常用的布局管理器,让控件自动调整位置和大小。常见的布局管理器有:
我们来创建一个包含多个控件的窗口,使用 QVBoxLayout 和 QHBoxLayout 来组织这些控件。
完整代码:
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QWidget, QVBoxLayout, QHBoxLayout, QPushButton, QLabel
# 创建一个主窗口类,继承自 QMainWindow
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("PyQt5 布局示例")
# 设置窗口标题
# 创建主窗口中的中央控件,QMainWindow 需要设置中央控件
central_widget = QWidget(self)
self.setCentralWidget(central_widget)
# 创建垂直布局管理器
vbox_layout = QVBoxLayout()
# 创建标签控件并添加到布局中
label = QLabel("这是一个标签")
vbox_layout.addWidget(label)
# 创建水平布局管理器
hbox_layout = QHBoxLayout()
# 创建两个按钮,并添加到水平布局中
button1 = QPushButton("按钮 1")
button2 = QPushButton("按钮 2")
hbox_layout.addWidget(button1)
hbox_layout.addWidget(button2)
# 将水平布局添加到垂直布局中
vbox_layout.addLayout(hbox_layout)
# 将布局设置为中央控件的布局
central_widget.setLayout(vbox_layout)
# 创建应用程序对象
app = QApplication(sys.argv)
# 创建主窗口
window = MainWindow()
window.show()
# 进入应用程序的事件循环
sys.exit(app.exec_())
QWidget 与 QMainWindow:
QMainWindow 作为主窗口,主窗口需要设置一个中央控件,所以我们创建了一个 QWidget 实例 central_widget。setCentralWidget() 方法用于将 QWidget 设置为 QMainWindow 的中央控件,这个中央控件是放置所有其他控件的容器。QVBoxLayout 是一个垂直布局管理器,控件会从上到下排列。QHBoxLayout 是一个水平布局管理器,控件会从左到右排列。vbox_layout.addWidget(label) 将标签控件添加到垂直布局中。hbox_layout.addWidget(button1) 和 hbox_layout.addWidget(button2) 将按钮控件添加到水平布局中。通过 vbox_layout.addLayout(hbox_layout),我们将水平布局嵌入到垂直布局中,实现更复杂的布局结构。

QGridLayout 允许你以网格的形式排列控件,每个控件可以放置在指定的行和列中。它适合用来创建表单或矩阵式的控件布局。
QGridLayout 示例:
from PyQt5.QtWidgets import QApplication, QWidget, QGridLayout, QLabel, QPushButton
import sys
class MainWindow(QWidget):
def __init__(self):
super().__init__()
self.setWindowTitle("QGridLayout 示例")
# 创建一个网格布局
layout = QGridLayout()
# 添加控件到网格布局的特定行和列
layout.addWidget(QLabel("标签 1"), 0, 0) # 在第 0 行,第 0 列添加标签
layout.addWidget(QPushButton("按钮 1"), 0, 1) # 在第 0 行,第 1 列添加按钮
layout.addWidget(QLabel("标签 2"), 1, 0) # 在第 1 行,第 0 列添加标签
layout.addWidget(QPushButton("按钮 2"), 1, 1) # 在第 1 行,第 1 列添加按钮
# 将布局设置为窗口的布局
self.setLayout(layout)
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec_())
QGridLayout():创建了一个网格布局对象。addWidget(widget, row, column):将控件添加到指定的行和列中,比如 (0, 0) 表示控件放置在第一行第一列。
在这一部分中,我们学习了如何在 PyQt5 中使用布局管理器来组织窗口内的控件。我们主要介绍了几种常见的布局方式:
通过使用这些布局管理器,我们可以让窗口中的控件自动调整位置和大小,而不需要手动计算控件的坐标。
这部分在之后还会有更加详细的介绍。
在 PyQt5 中,常用的控件(也称为小部件)有很多,它们可以用来实现用户界面中的各种元素,比如按钮、文本框、复选框等。接下来,我们将逐一介绍,并展示如何使用这些控件。
QLabel 是一个用于显示文本或图片的控件。它是最简单的控件之一,常用于显示静态文本。
代码示例:
from PyQt5.QtWidgets import QApplication, QLabel, QMainWindow
from PyQt5.QtCore import Qt
import sys
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("QLabel 示例")
# 创建标签并设置文本
label = QLabel("这是一个标签", self)
# 设置标签的对齐方式
label.setAlignment(Qt.AlignCenter)
# 设置标签为中央控件
self.setCentralWidget(label)
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec_())
QLabel:用于显示文本的控件。你可以设置标签的内容、字体、对齐方式等。setAlignment(Qt.AlignCenter):将标签的文本设置为居中对齐。self.setCentralWidget(label):将标签设置为窗口的中央控件。
QPushButton 是一个按钮控件,用户可以点击按钮来触发事件。它是最常见的控件之一。
代码示例:
from PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton
import sys
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("QPushButton 示例")
# 创建按钮
button = QPushButton("点击我", self)
# 设置按钮点击事件
button.clicked.connect(self.button_clicked)
# 将按钮设置为窗口的中央控件
self.setCentralWidget(button)
# 定义按钮点击时触发的事件
def button_clicked(self):
print("按钮被点击!")
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec_())
QPushButton:创建了一个按钮控件,显示文本为'点击我'。button.clicked.connect(self.button_clicked):连接按钮的点击信号到自定义的 button_clicked 方法。当按钮被点击时,这个方法会被触发。self.button_clicked:定义了一个槽函数,用于响应按钮点击事件。在槽函数中,程序会打印'按钮被点击!'。
QLineEdit 是一个单行文本框,用于让用户输入文本。你可以获取用户输入的文本并对其进行处理。
代码示例:
from PyQt5.QtWidgets import QApplication, QMainWindow, QLineEdit
import sys
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("QLineEdit 示例")
# 创建文本框
self.line_edit = QLineEdit(self)
# 设置默认提示文本
self.line_edit.setPlaceholderText("请输入文本")
# 将文本框设置为中央控件
self.setCentralWidget(self.line_edit)
# 连接文本输入结束的信号到槽函数
self.line_edit.returnPressed.connect(self.return_pressed)
def return_pressed(self):
# 获取用户输入的文本
text = self.line_edit.text()
print(f"用户输入:{text}")
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec_())
QLineEdit:创建了一个单行文本框控件,允许用户输入文本。setPlaceholderText():设置占位符文本,当用户没有输入时显示提示文本。self.line_edit.returnPressed.connect(self.return_pressed):连接用户按下'回车键'时的信号到 return_pressed 槽函数,获取输入文本并打印出来。
QCheckBox 是一个复选框,用户可以选择或取消选择该选项。它通常用于让用户勾选某些偏好或选项。
代码示例:
from PyQt5.QtWidgets import QApplication, QMainWindow, QCheckBox
from PyQt5.QtCore import Qt
import sys
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("QCheckBox 示例")
# 创建复选框
self.checkbox = QCheckBox("同意条款", self)
# 设置复选框状态改变事件
self.checkbox.stateChanged.connect(self.checkbox_changed)
# 将复选框设置为中央控件
self.setCentralWidget(self.checkbox)
def checkbox_changed(self, state):
if state == Qt.Checked:
print("复选框被勾选")
else:
print("复选框未被勾选")
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec_())
QCheckBox:创建一个复选框,显示文本为'同意条款'。self.checkbox.stateChanged.connect(self.checkbox_changed):连接复选框状态改变的信号到槽函数 checkbox_changed,当用户勾选或取消勾选时会触发相应的事件。checkbox_changed(self, state):根据复选框的状态(勾选或未勾选)打印相应的消息。
QComboBox 是一个下拉列表控件,用户可以从中选择一个选项。
代码示例:
from PyQt5.QtWidgets import QApplication, QMainWindow, QComboBox
import sys
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("QComboBox 示例")
# 创建下拉列表
self.combobox = QComboBox(self)
# 添加选项
self.combobox.addItems(["选项 1", "选项 2", "选项 3"])
# 连接下拉列表选项改变事件
self.combobox.currentIndexChanged.connect(self.combobox_changed)
# 将下拉列表设置为中央控件
self.setCentralWidget(self.combobox)
def combobox_changed(self, index):
# 获取当前选中的文本
text = self.combobox.currentText()
print(f"当前选中:{text}")
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec_())
QComboBox:创建一个下拉列表控件,用户可以从中选择选项。self.combobox.addItems():向下拉列表中添加选项。currentIndexChanged.connect():连接下拉列表选项改变的信号到 combobox_changed 槽函数,当用户选择不同的选项时会打印选中的文本。
在这一部分中,我们介绍了 PyQt5 中一些常见的控件,分别是:
这些控件是 GUI 应用程序的基础组成部分,它们让应用程序更加互动和可操作。
第 1 至第 3 部分中,我们介绍了 PyQt5 的基础知识和一些常用的控件。首先,我们讲解了如何安装 PyQt5,并创建了一个简单的 PyQt5 应用程序。接着,介绍了布局管理器(如 QVBoxLayout 和 QHBoxLayout),并通过它们组织界面中的控件。最后,我们深入探讨了 PyQt5 中的常用控件,如 QLabel、QPushButton、QLineEdit 和 QCheckBox,展示了如何使用这些控件处理基本的用户交互。

微信公众号「极客日志」,在微信中扫描左侧二维码关注。展示文案:极客日志 zeeklog
解析常见 curl 参数并生成 fetch、axios、PHP curl 或 Python requests 示例代码。 在线工具,curl 转代码在线工具,online
将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online
将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online
将 Markdown(GFM)转为 HTML 片段,浏览器内 marked 解析;与 HTML 转 Markdown 互为补充。 在线工具,Markdown 转 HTML在线工具,online
将 HTML 片段转为 GitHub Flavored Markdown,支持标题、列表、链接、代码块与表格等;浏览器内处理,可链接预填。 在线工具,HTML 转 Markdown在线工具,online
通过删除不必要的空白来缩小和压缩JSON。 在线工具,JSON 压缩在线工具,online