Python小白逆袭!7天吃透PyQt6,独立开发超酷桌面应用
liuian 2025-07-17 20:35 3 浏览
Python GUI编程:PyQt6从入门到实战的全面指南
在Python的庞大生态系统中,PyQt6作为一款强大的GUI(Graphical User Interface,图形用户界面)编程框架,为开发者们提供了创建交互式桌面应用程序的有力工具。无论你是想开发一个简单的文件管理工具,还是一个复杂的图像编辑软件,PyQt6都能满足你的需求。本文将带你从PyQt6的基础知识开始,逐步深入到实战项目,帮助你掌握这一强大的GUI编程技术。
一、PyQt6简介
PyQt6是Qt应用框架的Python绑定版本,由Riverbank Computing开发。Qt是一个跨平台的C++应用开发框架,以其高效、灵活和强大的功能而闻名。PyQt6允许开发者使用Python语言编写Qt应用程序,结合了Python的简洁性和Qt的强大功能,使得GUI开发变得更加容易和高效。它支持Windows、Linux、macOS等多种主流操作系统,并且提供了丰富的控件库,包括按钮、文本框、菜单、表格等,能够满足各种界面设计需求。
二、环境搭建
在开始使用PyQt6进行开发之前,需要先安装PyQt6库。如果你已经安装了Python和pip(Python的包管理工具),可以通过以下命令进行安装:
pip install PyQt6
安装完成后,还可以安装PyQt6的设计工具pyqt6-tools,它包含了Qt Designer,这是一个可视化的界面设计工具,可以大大提高开发效率:
pip install pyqt6-tools
安装完成后,在PyCharm等集成开发环境中,可以通过配置外部工具来使用Qt Designer。具体配置方法如下:
1. 打开PyCharm,进入File -> Settings(Windows/Linux)或PyCharm -> Preferences(Mac)。
2. 在左侧菜单中选择Tools -> External Tools。
3. 点击右上角的+按钮,添加一个新的外部工具。
4. 在Name中输入Qt Designer,在Description中输入描述信息(可选)。
5. 在Program中输入Qt Designer的可执行文件路径,一般位于Python安装目录下的Lib\site-packages\qt6_applications\Qt\bin\designer.exe(Windows)或相应的路径(Linux/Mac)。
6. 在Working directory中输入$ProjectFileDir$。
7. 点击OK保存设置。
这样,就可以在PyCharm中通过Tools -> External Tools -> Qt Designer来启动Qt Designer了。
三、第一个PyQt6程序
下面通过一个简单的示例,来创建一个基本的PyQt6窗口:
import sys
from PyQt6.QtWidgets import QApplication, QWidget
if __name__ == '__main__':
app = QApplication(sys.argv) # 创建QApplication实例,管理GUI应用的控制流和主要设置
window = QWidget() # 创建一个QWidget实例,作为主窗口
window.setWindowTitle('第一个PyQt6程序') # 设置窗口标题
window.setGeometry(100, 100, 400, 300) # 设置窗口的位置和大小,(x, y, width, height)
window.show() # 显示窗口
sys.exit(app.exec()) # 进入应用程序的主循环,等待用户操作,直到窗口关闭
在这个示例中:
1. 首先导入了sys模块和QApplication、QWidget类。sys模块用于处理命令行参数,QApplication类管理GUI应用的控制流和主要设置,QWidget类是所有用户界面对象的基类,这里用作主窗口。
2. 创建了QApplication实例app,并将命令行参数sys.argv传递给它。
3. 创建了QWidget实例window,并设置了窗口标题和大小。
4. 调用window.show()方法显示窗口。
5. 最后通过sys.exit(app.exec())进入应用程序的主循环,app.exec()会处理各种事件,直到窗口关闭,程序退出。
四、常用控件与布局管理
常用控件
PyQt6提供了丰富的控件,如按钮(QPushButton)、标签(QLabel)、文本框(QLineEdit)、复选框(QCheckBox)、下拉框(QComboBox)等。下面是一个包含多种控件的示例:
import sys
from PyQt6.QtWidgets import QApplication, QWidget, QVBoxLayout, QLabel, QLineEdit, QPushButton, QCheckBox, QComboBox
class MainWindow(QWidget):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
# 创建标签
self.label = QLabel('用户名:', self)
# 创建文本框
self.line_edit = QLineEdit(self)
# 创建按钮
self.button = QPushButton('提交', self)
self.button.clicked.connect(self.on_button_click) # 绑定按钮点击事件
# 创建复选框
self.checkbox = QCheckBox('记住密码', self)
# 创建下拉框
self.combo_box = QComboBox(self)
self.combo_box.addItems(['选项1', '选项2', '选项3'])
# 创建垂直布局管理器
layout = QVBoxLayout()
layout.addWidget(self.label)
layout.addWidget(self.line_edit)
layout.addWidget(self.button)
layout.addWidget(self.checkbox)
layout.addWidget(self.combo_box)
self.setLayout(layout) # 将布局管理器应用到窗口
self.setWindowTitle('控件示例')
self.setGeometry(100, 100, 300, 250)
def on_button_click(self):
username = self.line_edit.text()
remember = self.checkbox.isChecked()
selected_option = self.combo_box.currentText()
print(f'用户名:{username},记住密码:{remember},选择的选项:{selected_option}')
if __name__ == '__main__':
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec())
在这个示例中:
1. 创建了QLabel、QLineEdit、QPushButton、QCheckBox和QComboBox等控件。
2. 使用QVBoxLayout垂直布局管理器将这些控件依次垂直排列。
3. 为按钮的clicked信号绑定了on_button_click槽函数,当按钮被点击时,会获取文本框、复选框和下拉框的值并打印出来。
布局管理
布局管理是GUI开发中非常重要的一部分,它决定了控件在窗口中的位置和大小。PyQt6提供了多种布局管理器,如QHBoxLayout(水平布局)、QVBoxLayout(垂直布局)、QGridLayout(网格布局)、QFormLayout(表单布局)等。
o 水平布局(QHBoxLayout):将控件从左到右水平排列。
o 垂直布局(QVBoxLayout):将控件从上到下垂直排列。
o 网格布局(QGridLayout):将控件排列在一个网格中,可以指定控件所在的行和列。
o 表单布局(QFormLayout):常用于创建表单,将标签和输入控件成对排列。
例如,使用QGridLayout创建一个简单的计算器界面:
import sys
from PyQt6.QtWidgets import QApplication, QWidget, QGridLayout, QPushButton
class Calculator(QWidget):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
buttons = [
'7', '8', '9', '/',
'4', '5', '6', '*',
'1', '2', '3', '-',
'0', '.', '=', '+',
]
grid = QGridLayout()
row = 0
col = 0
for button_text in buttons:
button = QPushButton(button_text, self)
button.clicked.connect(self.on_button_click)
grid.addWidget(button, row, col)
col += 1
if col > 3:
col = 0
row += 1
self.setLayout(grid)
self.setWindowTitle('简单计算器')
self.setGeometry(100, 100, 300, 300)
def on_button_click(self):
sender = self.sender()
print(sender.text())
if __name__ == '__main__':
app = QApplication(sys.argv)
window = Calculator()
window.show()
sys.exit(app.exec())
在这个示例中:
1. 创建了一个包含数字和运算符的按钮列表。
2. 使用QGridLayout将这些按钮排列在一个4x4的网格中。
3. 为每个按钮的clicked信号绑定了on_button_click槽函数,当按钮被点击时,会打印出按钮上的文本。
五、信号与槽机制
信号与槽是PyQt6中对象间通信的机制。当一个特定事件发生时,对象会发射一个信号,而槽是一个被连接到信号的函数,当信号发射时,与之连接的槽函数会被自动调用。例如,前面示例中按钮的clicked信号与相应的槽函数的连接:
self.button.clicked.connect(self.on_button_click)
这里,self.button是一个QPushButton对象,clicked是它的一个信号,当按钮被点击时,会发射这个信号。self.on_button_click是一个槽函数,通过connect方法将信号和槽连接起来,当clicked信号发射时,on_button_click函数就会被调用。
信号与槽机制使得代码的逻辑更加清晰和可维护,不同的对象之间可以通过信号与槽进行松耦合的通信。
六、实战项目:简易文本编辑器
下面通过一个实战项目,来创建一个简易的文本编辑器,综合运用前面所学的知识。这个文本编辑器将具备新建文件、打开文件、保存文件和基本的文本编辑功能。
import sys
from PyQt6.QtWidgets import QApplication, QMainWindow, QTextEdit, QAction, QFileDialog
from PyQt6.QtGui import QIcon
class TextEditor(QMainWindow):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
# 创建文本编辑区域
self.text_edit = QTextEdit()
self.setCentralWidget(self.text_edit)
# 创建菜单栏
menubar = self.menuBar()
# 文件菜单
file_menu = menubar.addMenu('文件')
# 新建文件动作
new_action = QAction(QIcon('new.png'), '新建', self)
new_action.setShortcut('Ctrl+N')
new_action.triggered.connect(self.new_file)
file_menu.addAction(new_action)
# 打开文件动作
open_action = QAction(QIcon('open.png'), '打开', self)
open_action.setShortcut('Ctrl+O')
open_action.triggered.connect(self.open_file)
file_menu.addAction(open_action)
# 保存文件动作
save_action = QAction(QIcon('save.png'), '保存', self)
save_action.setShortcut('Ctrl+S')
save_action.triggered.connect(self.save_file)
file_menu.addAction(save_action)
self.setWindowTitle('简易文本编辑器')
self.setGeometry(100, 100, 800, 600)
def new_file(self):
self.text_edit.clear()
def open_file(self):
file_path, _ =
QFileDialog.getOpenFileName(self, '打开文件', '', '文本文件 (*.txt)')
if file_path:
with open(file_path, 'r', encoding='utf-8') as f:
self.text_edit.setText(f.read())
def save_file(self):
file_path, _ =
QFileDialog.getSaveFileName(self, '保存文件', '', '文本文件 (*.txt)')
if file_path:
with open(file_path, 'w', encoding='utf-8') as f:
f.write(self.text_edit.toPlainText())
if __name__ == '__main__':
app = QApplication(sys.argv)
window = TextEditor()
window.show()
sys.exit(app.exec())
在这个项目中:
1. 创建了一个QMainWindow作为主窗口,并将QTextEdit设置为中心部件,用于文本编辑。
2. 创建了菜单栏,并在菜单栏中添加了文件菜单。
3. 在文件菜单中添加了新建、打开和保存三个动作,分别绑定了对应的槽函数new_file、open_file和save_file。
4. new_file函数用于清空文本编辑区域,open_file函数通过QFileDialog打开文件并读取内容显示在文本编辑区域,save_file函数通过QFileDialog选择保存路径并将文本编辑区域的内容保存到文件中。
七、总结与展望
通过本文的学习,你已经掌握了PyQt6的基础知识和实战技能,包括环境搭建、常用控件、布局管理、信号与槽机制以及一个简易文本编辑器的开发。PyQt6还有很多高级特性,如自定义样式(使用QSS)、多线程处理、数据库集成、图形绘制等,等待你进一步探索。
在实际开发中,可以根据项目需求,灵活运用PyQt6的各种功能,创建出功能强大、界面美观的桌面应用程序。同时,建议参考PyQt6的官方文档和更多优秀的开源项目,不断提升自己的GUI开发水平。
相关推荐
- Springboot 整合 Websocket 轻松实现IM及时通讯
-
一、方案实践集成分为三步:添加依赖、增加配置类和消息核心类、前端集成。1.1、添加依赖<dependency><groupId>org.springframework...
- SpringBoot扩展——应用Web Socket!
-
应用WebSocket目前,网络上的即时通信App有很多,如QQ、微信和飞书等,按照以往的技术来说,即时功能通常会采用服务器轮询和Comet技术来解决。HTTP是非持久化、单向的网络协议,在建立连接...
- 【Spring Boot】WebSocket 的 6 种集成方式
-
介绍由于前段时间我实现了一个库【SpringCloud】一个配置注解实现WebSocket集群方案以至于我对WebSocket的各种集成方式做了一些研究目前我所了解到的就是下面这些了(就一个破w...
- SpringBoot生产级WebSocket集群实践,支持10万连接!
-
1、问题背景智慧门诊系统旨在从一定程度上解决患者面临的三长一短(挂号、看病、取药时间长,医生问诊时间短)的问题。实现“诊前、诊中、诊后”实时智能一体化,整合完善医院工作流程。围绕门诊看病的各个环节,让...
- Spring Boot3 中 WebSocket 实现数据实时通信全解析
-
各位互联网大厂的开发同仁们,在如今的互联网应用开发中,实时通信功能越来越重要。比如在线聊天、数据推送、实时通知等场景,都离不开高效的实时通信技术。而WebSocket作为一种高效的双向通信协议,在...
- Java WebSocket 示例(java nio websocket)
-
一、环境准备1.依赖配置(Maven)在pom.xml中添加WebSocket依赖:xml<!--SpringBootWebSocket--><dependen...
- Spring Boot整合WebSocket:开启实时通信之旅
-
SpringBoot整合WebSocket:开启实时通信之旅今天咱们来聊聊SpringBoot整合WebSocket这件大事儿。说到实时通信,你是不是第一时间想到QQ、微信这些聊天工具?没错,We...
- Spring Boot3 竟能如此轻松整合 WebSocket 技术,你还不知道?
-
在当今互联网大厂的软件开发领域,实时通信的需求愈发迫切。无论是在线聊天应用、实时数据更新,还是协同办公系统,都离不开高效的实时通信技术支持。而WebSocket作为一种能够实现浏览器与服务器之间持...
- Spring Boot集成WebSocket(springboot集成websocket)
-
一、基础配置依赖引入<dependency><groupId>org.springframework.boot</groupId><artifactId>...
- Springboot下的WebSocket开发(springboot websocket server)
-
今天遇到一个需求,需要对接第三方扫码跳转。一种方案是前端页面轮询后端服务,但是这种空轮询会虚耗资源,实时性比较差而且也不优雅。所以决定使用另一种方案,websocket。以前就知道websocket,...
- springboot websocket开发(java spring boot websocket)
-
maven依赖SpringBoot2.0对WebSocket的支持简直太棒了,直接就有包可以引入<dependency><groupId>org....
- Python界面(GUI)编程PyQt5窗体小部件
-
一、简介在Qt(和大多数用户界面)中,“小部件”是用户可以与之交互的UI组件的名称。用户界面由布置在窗口内的多个小部件组成。Qt带有大量可用的小部件,也允许您创建自己的自定义和自定义小部件。二、小部件...
- 实战PyQt5: 014-下拉列表框控件QComboBox
-
QComboBox简介QComboBox下拉列表框,是一个集按钮和下拉列表选项于一体的部件。QComboBox提供了一种向用户呈现选项列表的方式,其占用最小量的屏幕空间。QComboBox中的常用方法...
- Python小白逆袭!7天吃透PyQt6,独立开发超酷桌面应用
-
PythonGUI编程:PyQt6从入门到实战的全面指南在Python的庞大生态系统中,PyQt6作为一款强大的GUI(GraphicalUserInterface,图形用户界面)编程框架,为开...
- 如何用 PyQt6 打造一个功能完善的 SQLite 数据库管理工具
-
如何使用PyQt6和qt_material库,打造一个功能完善的SQLite数据库管理工具,轻松管理和查询SQLite数据库。一、目标数据库连接与表管理:支持连接SQLite数据库...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
系统C盘清理:微信PC端文件清理,扩大C盘可用空间步骤
-
10款高性能NAS丨双十一必看,轻松搞定虚拟机、Docker、软路由
-
python使用fitz模块提取pdf中的图片
-
- 最近发表
-
- Springboot 整合 Websocket 轻松实现IM及时通讯
- SpringBoot扩展——应用Web Socket!
- 【Spring Boot】WebSocket 的 6 种集成方式
- SpringBoot生产级WebSocket集群实践,支持10万连接!
- Spring Boot3 中 WebSocket 实现数据实时通信全解析
- Java WebSocket 示例(java nio websocket)
- Spring Boot整合WebSocket:开启实时通信之旅
- Spring Boot3 竟能如此轻松整合 WebSocket 技术,你还不知道?
- Spring Boot集成WebSocket(springboot集成websocket)
- Springboot下的WebSocket开发(springboot websocket server)
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)