我的代码有一个带有复选框的组合框,每当我选中一个复选框时,我想在QTableWidget行中显示文本,如果未选中复选框,则要从QTableWidget中删除该行。

最佳答案

尽管从长远来看,最初使用带有QCombobox的QTableWidget管理逻辑似乎很简单,但可能会很复杂。更为优雅的解决方案是使用由QComboBox和QTableView共享的模型,其中由QSortFilterProxyModel进行过滤,当共享两个元素时,同一模型将看到QTableWidget中的复选框,该复选框已被委托删除。

from PyQt5 import QtCore, QtGui, QtWidgets


class CheckedFilterProxyModel(QtCore.QSortFilterProxyModel):
    def filterAcceptsRow(self, source_row, source_parent):
        index = self.sourceModel().index(source_row, 0, source_parent)
        return index.data(QtCore.Qt.CheckStateRole) == QtCore.Qt.Checked


class RemoveCheckBoxDelegate(QtWidgets.QStyledItemDelegate):
    def initStyleOption(self, option, index):
        super(RemoveCheckBoxDelegate, self).initStyleOption(option, index)
        option.features &= ~QtWidgets.QStyleOptionViewItem.HasCheckIndicator


class Widget(QtWidgets.QWidget):
    def __init__(self, parent=None):
        super(Widget, self).__init__(parent)

        self.m_combobox = QtWidgets.QComboBox()
        self.m_tableview = QtWidgets.QTableView()

        self.m_model = QtGui.QStandardItemModel(0, 2)
        self.m_proxy = CheckedFilterProxyModel(self)
        self.m_proxy.setSourceModel(self.m_model)

        self.m_combobox.setModel(self.m_model)
        self.m_tableview.setModel(self.m_proxy)

        delegate = RemoveCheckBoxDelegate(self)
        self.m_tableview.setItemDelegateForColumn(0, delegate)

        lay = QtWidgets.QVBoxLayout(self)
        lay.addWidget(self.m_combobox)
        lay.addWidget(self.m_tableview)

        options = ["Test1", "Test2", "Test3"]

        self.fill_combobox(options)

    def fill_combobox(self, options):
        self.m_model.clear()
        for option in options:
            item = QtGui.QStandardItem(option)
            item.setFlags(QtCore.Qt.ItemIsUserCheckable | QtCore.Qt.ItemIsEnabled)
            item.setData(QtCore.Qt.Unchecked, QtCore.Qt.CheckStateRole)
            items = [item] + [
                QtGui.QStandardItem() for _ in range(self.m_model.rowCount() - 1)
            ]
            self.m_model.appendRow(items)


if __name__ == "__main__":
    import sys

    app = QtWidgets.QApplication(sys.argv)

    w = Widget()
    w.show()

    sys.exit(app.exec_())

关于python - 将可检查组合框的文本显示到QTableWidget,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/57933642/

10-13 09:38