一、环境搭建
安装pyqt5
pip install pyqt5
安装pyqt5-tools
pip install pyqt5-tools
配置工具
1、配置QtDesigner
- 配置路径 settings–>Tools–>External Tools
- 点击 + ,创建工具
data:image/s3,"s3://crabby-images/0463a/0463ae043ed52c31c63e01d3c85cb361554d4687" alt="请添加图片描述" - 配置项
Name:自定义
Program: D:\Code\python\config\venv\Lib\site-packages\qt5_applications\Qt\bin\designer.exe
Working directory:$FileDir$
2、配置pyuic
data:image/s3,"s3://crabby-images/1f64a/1f64a11b99fb1b8a5c73482a8d6829425282b51c" alt="请添加图片描述"
Name:Pyuic
Program:D:\Code\python\config\venv\Scripts\pyuic5.exe
Arguments:$FileName$ -o $FileNameWithoutExtension$_ui.py -x
Working directory:$FileDir$
3、配置pyqrc
data:image/s3,"s3://crabby-images/54457/54457aa459c9e780f97b3e8bcbacb6eaf35bf85e" alt="请添加图片描述"
Name : pyqrc
Program:D:\Code\python\config\venv\Scripts\pyrcc5.exe
Arguments:$FileName$ -o $FileNameWithoutExtension$_rc.py
Working:$FileDir$
二、案例(登录界面)
1、开发前说明
- 注意:
(1)写代码前把项目的根目录设置为 root (后期导包不会标红,导包也会有提示) data:image/s3,"s3://crabby-images/fa576/fa5768cc8e9c3cf51be0506c1d09f9919754f600" alt="请添加图片描述" (2)在UI目录上打开qtDedigner(这样创建的文件自动到这个目录下) data:image/s3,"s3://crabby-images/80879/808794f6b7e728a550cb80c793a165146b4e9334" alt="请添加图片描述" - 前后端分离
- 目录结构
data:image/s3,"s3://crabby-images/c1950/c19509d7be870f120b1307d405e71e4a29f864fd" alt="请添加图片描述"
2、创建ui文件
- 打开 qtDesigner
- 用Widget模板创建
Widget、Main Window、Dialog 区别
Widget:空白窗体
Main Window:在widget的基础上多了顶部工具栏,底部状态栏
Dialog:对话框
- 保存 、命名 (我命名为login)
data:image/s3,"s3://crabby-images/8c5d8/8c5d81d35bf3b943c3ed4aeb69eba76917f45a41" alt="请添加图片描述" - 拖动组件
用到的组件是QPushButton 、 label、lineEdit data:image/s3,"s3://crabby-images/62bd3/62bd3ec3403af452058d0ca4a8c81a057fd339a7" alt="请添加图片描述"
3、转代码
- ui ----> py
data:image/s3,"s3://crabby-images/38de5/38de558b089499ee9360285bcb9ec40c9f8f7678" alt="请添加图片描述" - login_ui.py 拖到 resources 目录下
data:image/s3,"s3://crabby-images/c5de3/c5de3a189f454baa8cfe5aeb38839ce095cd9f9e" alt="请添加图片描述"
4、建立业务代码
- 在project 2021 9.7 下 建立LoginPane,并书写如下代码
from PyQt5.QtWidgets import QWidget,QApplication
from resources.login_ui import Ui_Form
import sys
class LoginPane(QWidget):
def __init__(self,parent=None):
super().__init__(parent)
self.ui = Ui_Form()
self.ui.setupUi(self)
if __name__ == '__main__':
app = QApplication(sys.argv)
loginpane = LoginPane()
loginpane.show()
sys.exit(app.exec_())
|