Я ответил на аналогичный вопрос на Как создать древовидное представление (с флажком) внутри поля со списком - PyQt , но в любом случае и для полноты ответа я вставлю вас сюда:
Вы должны создать модель, которая поддерживает Qt.CheckStateRole в методах data и SetData и флаг Qt.ItemIsUserCheckable в методе flags.
Вставьте вам пример, который я использую в проекте, этоуниверсальная реализация QSortFilterProxyModel для использования в любой модели, но вы можете использовать те же идеи в реализации вашей модели, очевидно, я использую внутренние структуры в этом подклассе, которых у вас нет непосредственно в PyQt, и они привязаны к моей внутренней реализации (self.booleanSet и self.readOnlySet).
def flags(self, index):
if not index.isValid():
return Qt.ItemIsEnabled
if index.column() in self.booleanSet:
return Qt.ItemIsUserCheckable | Qt.ItemIsSelectable | Qt.ItemIsEnabled
elif index.column() in self.readOnlySet:
return Qt.ItemIsSelectable | Qt.ItemIsEnabled
else:
return QSortFilterProxyModel.flags(self, index)
def data(self, index, role):
if not index.isValid():
return QVariant()
if index.column() in self.booleanSet and role in (Qt.CheckStateRole, Qt.DisplayRole):
if role == Qt.CheckStateRole:
value = QVariant(Qt.Checked) if index.data(Qt.EditRole).toBool() else QVariant(Qt.Unchecked)
return value
else: #if role == Qt.DisplayRole:
return QVariant()
else:
return QSortFilterProxyModel.data(self, index, role)
def setData(self, index, data, role):
if not index.isValid():
return False
if index.column() in self.booleanSet and role == Qt.CheckStateRole:
value = QVariant(True) if data.toInt()[0] == Qt.Checked else QVariant(False)
return QSortFilterProxyModel.setData(self, index, value, Qt.EditRole)
else:
return QSortFilterProxyModel.setData(self, index, data, role)