一、PyQt6简介
PyQt6 Digia 公司的 Qt 程序的 Python 中间件。Qt库是最强大的GUI库之一,很快就能完成功能较为丰富的桌面开发。
PyQt6 是基于 Python 的一系列模块。它是一个多平台的工具包,可以在包括Unix、Windows和Mac OS在内的大部分主要操作系统上运行。
PyQt6 有两个许可证,开发人员可以在 GPL 和商业许可之间进行选择。商业许可(闭源引用)一个开发者550刀,赚钱之后无所谓了;不赚钱就GPL(开源引用)也无所谓,所以放心使用。
二、PyQt6基本原理与功能
在PyQt6中,应用程序类是QApplication类的实例。它是整个GUI应用程序的入口,负责管理应用程序的生命周期和全局设置。
窗口类是QWidget或其子类的实例。它是GUI应用程序中的一个组成部分,负责显示和处理用户界面。
应用程序类负责管理整个GUI应用程序的生命周期和全局设置,而窗口类则负责显示和处理用户界面。在实际的应用程序中,通常会创建一个应用程序类的实例,并在其中创建多个窗口类的实例。
2.1 主要模块介绍
- QtCore - 其他模块使用的核心非 GUI 类
用来处理时间、文件、目录、各种类型的数据、流 (stream)、URLs,mime 类型、线程和进程。
- QtGui - 图形用户界面组件
窗口系统集成、事件处理、2D 图形,基本图像、字体、文本的类。
- QtWidgets - 构建图形用户界面(GUI)的各种小部件
包含了一系列常用的 GUI 小部件,如按钮、文本框、列表框、滑块等。这些小部件可以用来创建用户界面,并通过事件处理来响应用户的操作。
用户界面窗口主要类型:
QWidget:所有用户界面对象的基类,拥有丰富的小部件(如按钮、输入框)
Widget | What it does |
QCheckbox | A checkbox |
QComboBox | A dropdown list box |
QDateEdit | For editing dates and datetimes |
QDateTimeEdit | For editing dates and datetimes |
QDial | Rotatable dial |
QDoubleSpinBox | A number spinner for floats |
QFontComboBox | A list of fonts |
QLCDNumber | A quite ugly LCD display |
QLabel | Just a label, not interactive |
QLineEdit | Enter a line of text |
QProgressBar | A progress bar |
QPushButton | A button |
QRadioButton | A toggle set, with only one active item |
QSlider | A slider |
QSpinBox | An integer spinner |
QTimeEdit | For editing times |
QMainWindow:主窗口基类,提供一个主应用程序窗口、一个框架,用于构建应用程序用户界面,拥有自己的布局,可以访问QStatusBar、QToolbar等。
QDialog:对话窗口基类,主要用于短期任务的顶级窗口交互
如果需要嵌入到其他窗体中,则基于QWidget创建;如果是顶级对话框,则基于QDialog创建;如果是主窗体,则基于QMainWindow创建。
- QtNetwork - 网络编程类,支撑TCP/IP 和 UDP 服务端和客户端编程
- QtHelp - 包含了创建、查看和搜索文档的类
- QtXml - 包含了处理 XML 文件的类,实现了 SAX 和 DOM API
- QtSql - 模块提供了数据库的类
- QtTest - 提供了可以对 PyQt6 应用进行单元测试的工具。
2.2 事件驱动模型
GUI 应用程序是事件驱动的。事件主要由应用程序的用户触发,但也可以通过其他方式生成,例如 Internet 连接、窗口管理器或定时器。当我们调用应用程序的 exec() 方法时,应用程序进入主循环。主循环获取事件并将它们发送到对象。
在事件模型里(事件源对象将处理事件的任务委托给事件目标),有三个要素:
- 事件源 event source,事件源是状态改变的对象,它会产生事件
- 事件对象 event object,封装了事件源中的状态变化
- 事件目标 event target,要被通知的对象
三、PyQt6实例 - 简单记事本例子
3.1 需求说明
一个简单记事本例子,有菜单、工具栏、编辑文本框以及状态栏,可以选择一个文本文件,使用“打开”功能后打开的文件,起内容被加载到文本编辑小部件中。
3.2 源码
# -*- coding: utf-8 -*-
import sys
import os
from PyQt6 import QtWidgets,QtGui
class NotePad(QtWidgets.QMainWindow):
def __init__(self):
super().__init__()
self.startUI()
def startUI(self):
#定义一个菜单,顶级名称显示文本
memubar = self.menuBar()
fileMenu = memubar.addMenu('&文件')
#定义动作
openFile = QtGui.QAction('打开',self)
#设置快捷键
openFile.setShortcut('Ctrl+O')
#鼠标悬停后,显示的提示文本
openFile.setStatusTip('打开新文件.')
#点击菜单时,绑定一个信号(动作),这里指定一个自定义函数(包含具体动作)
openFile.triggered.connect(self.displayDialogWindow)
#将动作绑定在菜单上
fileMenu.addAction(openFile)
#退出App功能,与打开文件雷同
exitApp = QtGui.QAction('&退出', self)
exitApp.setShortcut('Ctrl+Q')
exitApp.setStatusTip('退出应用')
#使用QT原生动作
exitApp.triggered.connect(QtWidgets.QApplication.instance().quit)
fileMenu.addAction(exitApp)
#定义一个工具栏
self.toolbar = self.addToolBar('文件')
#将打开文件绑定在工具栏上,动作与菜单动作一致
self.toolbar.addAction(openFile)
#将退出App绑定在工具栏上,动作与菜单动作一致
self.addToolBar('退出')
self.toolbar.addAction(exitApp)
#添加文本编辑框,文本编辑部件居中显示
self.textEdit = QtWidgets.QTextEdit()
self.setCentralWidget(self.textEdit)
#使用 QMainWindow 创建状态栏
self.statusBar().showMessage('Ready')
self.setGeometry(300,300,600,399)
self.setWindowTitle('Note Pad Sample')
self.show()
def displayDialogWindow(self):
homeDir = str(os.getcwd())
#getOpenFileName 的第一个参数字符串是标题,第二个字符串指定对话框工作目录。
#我们使用 os 模块来获取当前路径。默认情况下,文件过滤器设置为所有文件 (*)
fileName = QtWidgets.QFileDialog.getOpenFileName(self, '打开文件',homeDir)
if fileName[0]:
with open(fileName[0], 'r', encoding='utf-8') as f:
data = f.read()
self.textEdit.setText(data)
#为了标识执行代码的入口和避免文件被导入时被执行,我们可以将执行代码放入main函数中。
if __name__ == '__main__':
#定义应用程序
app = QtWidgets.QApplication(sys.argv)
#生成主界面
np = NotePad()
#调用应用程序的 exec() 方法时,应用程序进入主循环
sys.exit(app.exec())
3.3 验证结果
PS D:\Shangouxuehui_Git> & D:/Python312/python.exe d:/Shangouxuehui_Git/PythonBasicCases/notepad_sample.py
- 默认界面
- 导入文件
- 退出应用
https://github.com/ShanGouXueHui/PythonCases
##山狗学会 License Start##
转载请注明出处,"今日头条"创作者"山狗学会“ ,注明出处即授权,未注明出处罚款100万元
主页链接:山狗学会主页
##山狗学会 License End##