QtDeisgner,PyUic详细使用教程界面和函数逻辑分离(保姆教学)

关于QtDesigner可以pip也可以GitHub下载第三方的版本

                QtDesigner第三方插件版https://github.com/PyQt5/QtDesigner/releases

可以直接生成PyQt代码,省去PyUic

视频教学QtDesigner教程-界面和函数逻辑分离-实时修改布局_哔哩哔哩_bilibili

 首先打开QtDesigner生成好一个窗口,然后保存文件

这里是拍视频教学剩下的

 打开PyCharm找到Ui文件通过PyUic转成Py文件

QtDesigner插件版内部也是支持直接复制代码的,新建一个文件粘贴上去就好了

这一步就是Ui文件转成Py文件就行了

导入所需的东西

import PyQt5
from PyQt5.QtWidgets import QMainWindow
from untitled import Ui_Form

然后新建一个Py文件,在里边定义一个类继承QMainWindow和你的布局类(打开UI转换的Py文件就可以看到类名)

class MyGui(QMainWindow,Ui_Form):

然后在类里边定义

    def __init__(self):
        super().__init__()
        self.setupUi(self)

这样就初始化了你的窗口布局

然后最后边写上你的主入口

while True 
或者
if __name__ == '__main__':
甚至可以不写

推荐第二种写法

import sys
    app = PyQt5.QtWidgets.QApplication(sys.argv)
    MyUiStart = MyGui()
    MyUiStart.show()#       ui就会显示出来
    sys.exit(app.exec_())

然后就是加载主进程了你可以理解为这个程序一直在重复在窗口布局

这里MyGui是你定义的类名

最后你的界面就能显示出来了,并且实现了逻辑分离

更新布局的话只要用QtDesigner打开Ui文件然后修改内容把原来的布局代码覆盖掉就行了

完整的代码

布局代码

# -*- coding: utf-8 -*-

# Form implementation generated from reading ui file 'untitled.ui'
#
# Created by: PyQt5 UI code generator 5.15.4
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again.  Do not edit this file unless you know what you are doing.


from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_Form(object):
    def setupUi(self, Form):
        Form.setObjectName("Form")
        Form.resize(1100, 857)
        self.textBrowser = QtWidgets.QTextBrowser(Form)
        self.textBrowser.setGeometry(QtCore.QRect(230, 210, 651, 201))
        self.textBrowser.setObjectName("textBrowser")

        self.retranslateUi(Form)
        QtCore.QMetaObject.connectSlotsByName(Form)

    def retranslateUi(self, Form):
        _translate = QtCore.QCoreApplication.translate
        Form.setWindowTitle(_translate("Form", "Form"))
        self.textBrowser.setHtml(_translate("Form", "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.0//EN\" \"http://www.w3.org/TR/REC-html40/strict.dtd\">\n"
"<html><head><meta name=\"qrichtext\" content=\"1\" /><style type=\"text/css\">\n"
"p, li { white-space: pre-wrap; }\n"
"</style></head><body style=\" font-family:\'SimSun\'; font-size:9pt; font-weight:400; font-style:normal;\">\n"
"<p style=\" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;\"><span style=\" font-size:48pt; font-weight:600; font-style:italic;\">Hi My Firends</span></p></body></html>"))

主程序代码

#       首先导入布局类
import PyQt5
from PyQt5.QtWidgets import QMainWindow
from untitled import Ui_Form
#       这样就能继承这个窗口
#       这两个个是窗口必须要继承的
class MyGui(QMainWindow,Ui_Form):
    #       初始化窗口
    def __init__(self):
        super().__init__()
        self.setupUi(self)



if __name__ == '__main__':
    import sys
    app = PyQt5.QtWidgets.QApplication(sys.argv)
    MyUiStart = MyGui()
    MyUiStart.show()#       ui就会显示出来
    sys.exit(app.exec_())

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
PyQt6是一个Python的GUI框架,它可以用来开发交互式的桌面应用程序。在PyQt6中,逻辑界面分离的。这种分离的好处是可以更好地组织代码,并且可以让不同的开发人员专注于不同的任务。 实现PyQt6逻辑界面分离的方法如下: 1. 使用Qt Designer创建UI文件。Qt Designer是一个可视化的工具,可以帮助我们快速创建GUI界面。将所有的界面元素都放在UI文件中,而不是在代码中硬编码。 2. 使用PyUIC将UI文件转换成Python代码。PyUIC是一个命令行工具,它可以将UI文件转换成Python代码。使用命令行运行PyUIC,将UI文件转换成Python代码,并将其保存到一个.py文件中。 3. 在Python代码中编写逻辑代码。将所有的逻辑代码都放在一个单独的.py文件中。这个文件可以包含所有与界面相关的逻辑代码,例如按钮点击事件、文本输入等等。 4. 使用PyQt6加载UI文件并连接逻辑代码。在主程序中,使用PyQt6加载UI文件并连接逻辑代码。使用QMainWindow或QDialog作为主窗口,并将UI文件中的所有控件添加到主窗口中。连接逻辑代码和信号槽,以便在用户与界面交互时执行逻辑代码。 下面是一个简单的示例代码,演示了如何在PyQt6中实现逻辑界面分离: ```python # main.py from PyQt6.QtWidgets import QApplication, QMainWindow from PyQt6.uic import loadUi from logic import Logic class MainWindow(QMainWindow): def __init__(self): super().__init__() # Load the UI file loadUi('ui/mainwindow.ui', self) # Create an instance of the logic class self.logic = Logic() # Connect the buttons to the logic functions self.pushButton.clicked.connect(self.logic.on_button_clicked) if __name__ == '__main__': app = QApplication([]) window = MainWindow() window.show() app.exec() ``` ```python # logic.py class Logic: def on_button_clicked(self): print('Button clicked') ``` 在这个示例中,我们将界面元素放在了ui/mainwindow.ui文件中。我们使用loadUi()方法将UI文件加载到主窗口中。我们还创建了一个Logic类,其中包含了所有与界面相关的逻辑代码。我们将按钮的点击事件连接到Logic类中的on_button_clicked()函数。这样,当用户点击按钮时,逻辑代码就会执行。 通过这种方式,我们可以将逻辑界面分离,使代码更清晰、更易于维护。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值