处理多个QWidg

2024-06-17 18:28:53 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在用一个主QWidget构建一个解析器,它接收一个文件输入,打开一个新的QWidget并显示一个包含解析数据的表。你知道吗

但是,当我从主QWidget中选择一个新文件时,它将替换第二个QWidget,而不是实例化另一个QWidget。你知道吗

另外,我希望能够关闭主QWidget,关闭所有QWidget并退出程序。它现在没有这样做。你知道吗

完整代码:main.py

import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
from PyQt5.QtGui import QColor
from dbparser import DBParser
import xlsxwriter

class PopUp(QWidget):
def __init__(self, tablename, fields, rows):
    super(PopUp, self).__init__()
    #Window Property
    self.title = tablename
    self.left = 300
    self.top = 250
    self.width = 1000
    self.height = 750
    self.setWindowTitle(self.title)
    self.setGeometry(self.left, self.top, self.width, self.height)
    ...

class App(QWidget):
    def __init__(self):
    super().__init__()
    self.title = 'CMSDBParser'
    self.left = 150
    self.top = 150
    self.width = 500
    self.height = 200
    self.file = ""
    self.filepath = QLineEdit()
    self.bigEditor = QTextEdit()
    self.browse_btn = QPushButton('Browse...')
    self.parse_btn = QPushButton('Parse...')
    self.initUI()
    ...

    def parse(self):
        if self.file:
        try:
            parser = DBParser(self.file)
            dbcheck = parser.isDB()
            if dbcheck == True:
                tablename, fields, rows = parser.getData()

                self.popup = PopUp(tablename, fields, rows)
                self.popup.show()

            else:
                QMessageBox.information(self, 'Warning', 'Right format but not CMS DB File')

        except:
            QMessageBox.critical(self, 'Error', "Invalid File Selected \nMust be .txt or .log format")
    self.parse_btn.setEnabled(False)

if __name__ == '__main__':
app = QApplication(sys.argv)
ex = App()
sys.exit(app.exec_())

Tags: fromimportselffieldstitleinittopdef
1条回答
网友
1楼 · 发布于 2024-06-17 18:28:53

问题是,您使用的是同一个属性:self.popup,如果您创建另一个小部件,它将替换它,从而消除以前的窗口,在这种情况下,解决方案是创建一个存储PopUp的列表,另一方面,建议启用属性Qt::WA_DeleteOnClose,这样当PopUp关闭时,它将被消除这样就不会保留不必要的记忆。对于第二个需求,一个选项是覆盖closeEvent()方法并关闭PopUp,但要做到这一点,您必须验证它是否存在,因为从内存中删除项并不意味着您删除了列表中的引用。使用sip.isdeleted()

import sip

# others imports

class App(QWidget):
    def __init__(self):
        super().__init__()
        # ...
        self.popups = [] # < -

    def parse(self):
        if self.file:
            try:
                parser = DBParser(self.file)
                if parser.isDB():
                    tablename, fields, rows = parser.getData()
                    popup = PopUp(tablename, fields, rows)  # < -
                    popup.setAttribute(Qt.WA_DeleteOnClose) # < -
                    popup.show()                            # < -
                    self.popups.append(popup)               # < -
                else:
                    QMessageBox.information(self, 'Warning', 'Right format but not CMS DB File')
            except:
                QMessageBox.critical(self, 'Error', "Invalid File Selected \nMust be .txt or .log format")
        self.parse_btn.setEnabled(False)

    def closeEvent(self, event):
        for popup in self.popups:           # < -
            if not sip.isdeleted(popup):    # < -
                w.close()                   # < -
        super(App, self).closeEvent(event)  

相关问题 更多 >