python - 如何迭代使用 QStandardItemModel 创建的动态创建的复选框列表?

标签 python pyqt pyqt5 qstandarditemmodel

我正在创建一个应用程序,我需要使用另一个类(class)提供给我的列表来制作 list 。用户将选中他们想要的项目旁边的复选框,然后单击按钮。对于那些已检查的行,我想打印“您检查了号码 ___”。在相邻的 QBoxGroup 的 QLabel 中。

(在我的实际应用程序中,我正在迭代类,我将在类中调用函数)。我很难迭代我的列表,因为我必须检查该框是否已选中以及该名称是否是我想要打印的名称(打印的语句与实际名称不同,因为在我的应用程序中我将在我所在行的类中调用一个函数)。

我也不确定如何工作,如果用户使用 QLabel 选中多个框,我可以打印多个语句。我可能必须让用户一次只能选择一行,但这比上面的问题要小。

from PyQt5.QtWidgets import (QApplication, QTabWidget, QVBoxLayout, QWidget, QGridLayout, QLabel, QGroupBox,
                             QListView, QPushButton)
from PyQt5.QtGui import QStandardItem, QStandardItemModel
from PyQt5.QtCore import Qt
import sys, os

class MyPage(QWidget):
    def __init__(self):

        super().__init__()
        self.app = QApplication(sys.argv)
        self.screen = self.app.primaryScreen()
        self.size = self.screen.size()
        self.mydata = None

        # These numbers are arbitrary and seemed
        # to have the best balance
        self.textWidth = self.size.width() * 0.64
        self.chooseWidth = self.size.width() * 0.29

        self.createTextGroup()
        self.createStatsGroup()

        self.layout = QGridLayout()
        self.layout.addWidget(self.TextGroup, 0, 0, 0, 1)
        self.layout.addWidget(self.StatsGroup, 0, 1)
        self.setLayout(self.layout)
        self.show()

    # The left side of AnalysisTab containing the textbox
    # where the analysis will be shown
    def createTextGroup(self):
        self.TextGroup = QGroupBox("Analysis")
        self.TextGroup.setFixedWidth(self.textWidth)
        self.setStyleSheet("font: 15pt Tw Cen MT")

        # Here is where the analysis will go
        self.analysis = QLabel()

        self.layout = QGridLayout()
        self.layout.addWidget(self.analysis)
        self.TextGroup.setLayout(self.layout)

    # The right side of AnalysisTab containing a checklist of tests that
    # may be run on the data and a button to press to run the tests
    def createStatsGroup(self):
        self.StatsGroup = QGroupBox("Statistics Tests")
        self.StatsGroup.setFixedWidth(self.chooseWidth)
        self.setStyleSheet("font: 15pt Tw Cen MT")

        # List widgets where users will choose what analysis
        # they would like ran on their data
        self.statsAnalysis = QListView()
        self.model = QStandardItemModel(self.statsAnalysis)

        for member in myList(self):
            item = QStandardItem(member)
            item.setCheckable(True)
            check = Qt.Unchecked
            item.setCheckState(check)
            self.model.appendRow(item)

        self.statsButton = QPushButton("Analyze")
        self.statsButton.clicked.connect(self.statsButtonClicked)

        self.statsAnalysis.setModel(self.model)
        self.layout = QGridLayout()
        self.layout.addWidget(self.statsAnalysis, 0, 0, 0, 1)
        self.layout.addWidget(self.statsButton, 1, 1)
        self.StatsGroup.setLayout(self.layout)

    def statsButtonClicked(self):
        model2 = self.model
        for index in range(model2.rowCount()):
            item = model2.item(index)
            if item.checkState() == Qt.Unchecked and item == "One":
                self.analysis.setText("You checked number 1")
            elif item.checkState() == Qt.Unchecked and item == "One":
                self.analysis.setText("You checked number 2")
            elif item.checkState() == Qt.Unchecked and item == "One":
                self.analysis.setText("You checked number 3")
            elif item.checkState() == Qt.Unchecked and item == "One":
                self.analysis.setText("You checked number 4")
            elif item.checkState() == Qt.Unchecked and item == "One":
                self.analysis.setText("You checked number 5")
            else:
                self.analysis.setText("You didn't check anything")

def myList(self):
    thisList = ["One", "Two", "Three", "Four", "Five"]
    return thisList

def runStatsWiz():
    app = QApplication(sys.argv)
    myPage = MyPage()
    myPage.show()
    app.exec_()


runStatsWiz()

现在,statsButtonClicked() 函数返回 TypeError: 'QStandardItemModel' object is not callable

我已经尝试了这些 StackOverflow 页面上的信息,但我似乎无法弄清楚如何查看该行的名称以及该行是否被选中:

最佳答案

正如我在评论中指出的那样,您有一个类型,因为您有一个名为 self.model 的属性,但您想使用 self.model() 进行访问。

另一方面,你的逻辑是不正确的,因为例如它没有定义它是,另一方面假设这个错误不存在并且你用你的逻辑检查了2个选项您正在写“您检查了号码 X”,然后将其替换为“您检查了号码 Y”。

逻辑是将选中项的文本保存在列表中,如果该列表不为空,则连接信息,否则指示没有选中项。

def statsButtonClicked(self):
    checked_options = []
    for index in range(self.model.rowCount()):
        item = self.model.item(index)
        if item is not None and item.checkState() == Qt.Checked:
            checked_options.append(item.text())
    if checked_options:
        self.analysis.setText(
            "\n".join(["You checked number {}".format(option) for option in checked_options])
        )
    else:
        self.analysis.setText("You didn't check anything")

关于python - 如何迭代使用 QStandardItemModel 创建的动态创建的复选框列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59043789/

相关文章:

python - 用于搜索所有正在运行的 EC2 实例的 Lambda 函数,添加标签 'Name'(如果不存在),然后将标签添加到其关联的卷?

python - pyQT4 py3无法在QFrame背景中显示图像

python - 在 Linux 上部署 PyQt5 应用程序

python - 如何在 QLineedit 完成器中删除光标

python - 在 PyQt5 中打印 pdf 文档

python - Tornado - 如何实现长轮询客户端

javascript - 应用引擎 : logging events from the browser (JavaScript)

python - Pandas - df.fillna(df.mean()) 不适用于多索引 DataFrame

python - 在组小部件内添加两个水平对齐的单选按钮

python - mouseReleaseEvent 在应用程序启动时触发,而不是在 PyQt5 中单击时触发