可编辑 QTableView 中的 Pandas df:删除复选框

Posted

技术标签:

【中文标题】可编辑 QTableView 中的 Pandas df:删除复选框【英文标题】:Pandas df in editable QTableView: remove check boxes 【发布时间】:2016-12-19 22:54:00 【问题描述】:

我有一个 pandas 数据框,我想在 QtableView 中呈现并使其可编辑。我创建了以下模型,但由于某种原因,输出在每个字段中都有复选框。我怎样才能摆脱它们?

输出如下所示:

这是用于使熊猫数据框显示在 qtavleview 中并使其可编辑的模型(我使用的是 PySide)

class PandasModelEditable(QtCore.QAbstractTableModel):
    def __init__(self, data, parent=None):
        QtCore.QAbstractTableModel.__init__(self, parent)
        self._data = data

    def rowCount(self, parent=None):
        return len(self._data.values)

    def columnCount(self, parent=None):
        return self._data.columns.size

    def data(self, index, role=QtCore.Qt.DisplayRole):
        if index.isValid():
            if role == QtCore.Qt.DisplayRole or role == QtCore.Qt.EditRole:
                return unicode(self._data.iloc[index.row(), index.column()])
        return unicode()

    def headerData(self, section, orientation, role=QtCore.Qt.DisplayRole):
        if role != QtCore.Qt.DisplayRole:
            return None
        if orientation == QtCore.Qt.Horizontal:
            try:
                return '%s' % unicode(self._data.columns.tolist()[section])
            except (IndexError,):
                return unicode()
        elif orientation == QtCore.Qt.Vertical:
            try:
                return '%s' % unicode(self._data.index.tolist()[section])
            except (IndexError,):
                return unicode()

    def flags(self, index):
        return QtCore.Qt.ItemIsEnabled | QtCore.Qt.ItemIsSelectable | \
               QtCore.Qt.ItemIsEditable

    def setData(self, index, value, role=QtCore.Qt.EditRole):
        if index.isValid():
            self._data.iloc[index.row(), index.column()] = value
            if self.data(index, QtCore.Qt.DisplayRole) == value:
                self.dataChanged.emit(index, index)
                return True
        return unicode()

删除QtCore.Qt.ItemIsSelectable 并不能解决问题,因为它似乎没有任何效果。

【问题讨论】:

【参考方案1】:

您从 datasetaData 返回了错误的默认值。前者应该返回None(所以你可以删除最后一行),而后者应该返回False

【讨论】:

确实解决了问题。有什么解释为什么会导致这种意外行为? @nickpick。 data 方法返回一个QVariant,因此 Qt 只会将其转换为适合给定角色的任何值。空字符串转换为零,相当于Qt.Unchecked 我试图指出我在使用此代码时遇到的问题,但这里的回复已被删除,因此我提出了一个新问题:***.com/questions/44743509/…

以上是关于可编辑 QTableView 中的 Pandas df:删除复选框的主要内容,如果未能解决你的问题,请参考以下文章

将 pandas DataFrame 与 PyQt5 QTableView 同步

QTableView中的可编辑复选框仅列

复杂SQL查询的可编辑QTableView

踩坑QTableView之一:单列编辑

当模型是熊猫数据框时,使 QTableView 可编辑

如何使用 QSqlTableModel 在可编辑的 QTableView 中将值设置为 NULL