实现PyQt UI代码和逻辑代码分离

在使用Qt Disigner设计窗体后,将相应的.ui文件通过第三方工具转译为.py文件(以下称为主文件),然后习惯于在主文件下编写相关逻辑功能代码,
但是在后续的业务增加中,需要对窗体控件进行修改,形成新的.ui文件,转译后的文件会覆盖掉原先的文件,在对旧代码的转移,比较繁琐。

因此需要提前对UI界面代码和编写的逻辑代码分离

通过Qt Designer新建一个窗体

在这里插入图片描述

转译文件

在这里插入图片描述

其中较为主要的代码为

# window.py
from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        ...

建立一个新文件

导入相关的库,初始化窗体类。添加构造方法

import sys
import window  # 导入主文件
from PyQt5.QtWidgets import QApplication, QMainWindow, QMessageBox


class MasterWindows(QMainWindow, window.Ui_MainWindow):
    def __init__(self): # 构造方法
        super(MasterWindows, self).__init__()  # 运行父类的构造方法
        self.setupUi(self)  # 传递自己


if __name__ == '__main__':
    app = QApplication(sys.argv)  # 创建GUI
    ui = MasterWindows()  # 创建PyQt设计的窗体对象
    ui.show()  # 显示窗体
    sys.exit(app.exec_())  # 程序关闭时退出进程
编写逻辑代码

在类中自定义槽函数,在构造函数中为控件绑定槽函数

def info(self): # 自定义槽函数
	QMessageBox.information(None, "消息", "单击了按钮!", QMessageBox.Ok)
self.pushButton.clicked.connect(self.info) # 绑定槽函数

实现效果

请添加图片描述

完整代码

import sys
import window
from PyQt5.QtWidgets import QApplication, QMainWindow, QMessageBox


class MasterWindows(QMainWindow, window.Ui_MainWindow):
    def __init__(self):
        super(MasterWindows, self).__init__()  # 运行父类的构造方法
        self.setupUi(self)  # 传递自己
        self.pushButton.clicked.connect(self.info)

    def info(self):
        QMessageBox.information(None, "消息", "单击了按钮!", QMessageBox.Ok)


if __name__ == '__main__':
    app = QApplication(sys.argv)  # 创建GUI
    ui = MasterWindows()  # 创建PyQt设计的窗体对象
    ui.show()  # 显示窗体
    sys.exit(app.exec_())  # 程序关闭时退出进程
  • 10
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 8
    评论
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()函数。这样,当用户点击按钮时,逻辑代码就会执行。 通过这种方式,我们可以将逻辑和界面分离,使代码更清晰、更易于维护。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Meaauf

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值