赞
踩
最近接了一个小项目,主要任务是完成一个界面的设计,而且是基于Python,我第一反应就是使用大名鼎鼎的Qt来设计。Qt最早是用C语言开发的,但是后来也有了基于Python的第三方包,目前最新版是PyQt6.3,但是这个项目中使用的还是普及度更高的PyQt5。正好我也比较喜欢Python编程,于是边学边做,简单总结一些入门要点,授人与渔。
在此特别感谢Chat-GPT的帮助!真的是编程的利器!
要使用PyQt5,首先需要进行安装:pip install PyQt5
,如果想要尝鲜也可以安装PyQt6:pip install PyQt6
PyQt5主要有三个部分:【摘抄自网上】
QtCore
: 包含了核心的非GUI的功能。主要和时间、文件与文件夹、各种数据、模型、流、URLs、mime类文件、进程与线程一起使用。QtGui
: 包含了窗口系统、事件处理、2D图像、基本绘画、字体和文字类QtWidgets
: 包含了一些创建桌面的UI元素和控件了解包的结构还是非常有必要的,这样在看别人代码时能够有一个比较清晰的认识,也能快速定位到使用的包所在的位置。一般导入某个具体的类时会使用如下所示的import方式:
from PyQt5.QtWidgets import xxxx,xxxx
from PyQt5.QtGui import xxxxx,xxxx
from PyQt5.QtCore import xxxxxx,xxxxx
这里不太建议使用
from xxx import *
这样的导入方式,虽然一时省事了,但是对于后期代码的维护和给别人看都十分不友好,也不利于自己对这个包的理解。
如果是用C++开发Qt,那必须得下载一个Qt Creator,来实现代码和界面进行关联,使开发过程更加便捷。但是用PyQt5的Python第三方包来开发,只需要下载一个Qt Designer用来设计UI界面即可。
不过Qt Designer似乎不能通过下载一个执行程序来进行安装,而是通过下载第三方包的方式来下载。这里一般有两种方式。
PyQt5-Tools
: 运行上面的提到的安装PyQt5的命令pip install PyQt5
会自动安装sip(具体是啥有啥功能不太清楚),但不会自动安装Qt Designer,需要再安装PyQt5-Tools:pip install PyQt5-Tools
,然后在Python对应版本的site-packages
文件夹下面可以找到designer.exe
文件,即Qt Designer。
PySide2
: 除了安装PyQt5-Tools外,还可以安装PySide2这个包,就自带了Qt Designer这个软件,我采用的就是这种方式。和上面一样,也可以在Python的site-packages文件夹下找到,如下图所示。
PySide2和PyQt之间的兼容性据说不错,它们之间的关系可以在网上找到很多比较详细的叙述。
因此实际开发项目时,是使用Qt Designer来设计UI界面,得到一个.ui的文件,然后利用PyQt5安装时自带的工具pyuic5
将.ui文件转换为.py文件:
pyuic5 -o mywindow.py mywindow.ui #先是py文件名,再是ui文件名
当然,如果是使用VS Code写代码,也可以考虑安装一个插件,帮助你执行这行命令。
之后再新开一个py文件,进行逻辑编写,这样实现了界面与逻辑分离,代码结构更加清晰。如下图所示是一般项目的结构:
虽然网上有很多都是上来就写代码运行得到窗口的教程,但是个人建议初学者还是先使用软件设计好UI文件,再转换成代码的方式,这样更加直观,而且调整控件位置也更方便。
综上所述,PyQt5的开发主要是两个核心:ui界面的设计和逻辑代码的编写。前者主要是会玩Qt Designer这个软件即可;后者理清楚代码结构也不是很难。
先来看看ui界面怎么玩:打开Qt Designer,点击新建,会弹出一个窗口:
这里一般是选择Main Window或者Widget,其中Main Window继承自Widget,添加了一些内容,本质二者差不多。这里选择的是Widget。
建好文件后,得到一个空白页面,接下来就是往里面拖动控件并设计样式了,如下图所示。
这部分内容过于琐碎,这里只记录一些要点,后续随缘更新,遇到问题建议点对点搜索。
要想写好逻辑代码,首先要清楚它的基本结构。
前面提到,除ui界面代码,还需要有一个逻辑代码,而逻辑代码个人感觉使用类的形式来组织更加方便,也更优雅。还记得创建ui时选择的类吗?是Widget还是Main Window,逻辑代码类最好是继承这个这个类,即QWidget
或QMainWindow
。一般的代码结构如下所示。
# 先导入主要的三个模块和各自内部常用的类 from PyQt5 import QtCore, QtWidgets, QtGui from PyQt5.QtCore import pyqtSlot from PyQt5.QtWidgets import QApplication, QWidget from PyQt5.QtGui import QColor # 再导入设计的ui界面转换成的py文件 from Ui_window import Ui_Form class mywindow(QWidget): #这里一定要继承QWidget类或者是QMainWindow类 '''初始化函数 ''' def __init__(self) -> None: super().__init__() #先初始化父类【必须】 self.ui = Ui_Form() self.ui.setupUi(self) #这个函数本身需要传递一个QWidget类,而该类本身就继承了这个,所以可以直接传入self(这就是继承的好处) '''按钮连接的槽函数 ''' @pyqtSlot() #装饰器,表示该函数是按名称自动被连接 def on_pushButton_clicked(self): print("Pressed the pushButton") if __name__ == "__main__": # 这里的代码逻辑基本相同 app = QApplication([]) #先建立一个app wid = mywindow() #初始化一个对象,调用init函数,已加载设计的ui文件 wid.show() #显示这个ui app.exec_() #执行app(运行界面,响应按钮等操作)
这里有一个需要注意,那就是按钮连接的槽函数,这里没有调用connect
函数,而是使用了@pyqtSlot()
这个装饰器,但前提就是要求函数命名要按照规则来:on_(控件对象名)_信号名(self,内置参数)
。此外,想实现这个功能,还需要打开一个开关,这句代码默认在ui界面文件中就有,如下图所示。
这部分内容过于琐碎,后续随缘更新,个人建议拿不准先问问Chat-GPT怎么说 本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。