У меня есть QTableView, который показывает данные из базы данных sqlite. Судя по всему, я устанавливаю флажок для всех доступных строк данных. Проблема в том, что флажки нельзя установить, и при нажатии отображается следующая ошибка.
if value.toBool():
AttributeError: 'int' object has no attribute 'toBool'
Ниже приведен код, который я получил, но не дал желаемого результата. Я хотел бы выделить строку, флажок которой был установлен.
self.table_model3 = CheckboxSqlModel(0)
self.table_model3.setQuery("SELECT Name, Email FROM Individuals")
self.tableView3.setModel(self.table_model3)
self.tableView3.horizontalHeader().setStretchLastSection(True)
self.tableView3.setShowGrid(False)
self.table_model3.setHeaderData(0, QtCore.Qt.Horizontal, "All")
self.table_model3.setHeaderData(1, QtCore.Qt.Horizontal, "Client Name")
self.table_model3.setHeaderData(2, QtCore.Qt.Horizontal, "Email Address")
self.tableView3.setStyleSheet('QHeaderView:section{Background-color:#cdcdcd; font-family: Arial Narrow; font-size: 15px; height: 30px;}')
self.table_model3.insertColumn(0)
self.tableView3.setColumnWidth(0, 30)
class CheckboxSqlModel(QtSql.QSqlQueryModel):
def __init__(self, column):
super(CheckboxSqlModel, self).__init__()
self.column = column
self.checkboxes = list() #List of checkbox states
self.first = list() #Used to initialize checkboxes
#Make column editable
def flags(self, index):
flags = QtSql.QSqlQueryModel.flags(self, index)
if index.column() == self.column:
flags |= QtCore.Qt.ItemIsUserCheckable
return flags
def data(self, index, role=QtCore.Qt.DisplayRole):
row = index.row()
if index.column() == self.column and role == QtCore.Qt.CheckStateRole:
#Used to initialize
if row not in self.first :
index = self.createIndex(row, self.column)
self.first.append(row)
self.checkboxes.append(False)
return QtCore.Qt.Unchecked
#if checked
elif self.checkboxes[row]:
return QtCore.Qt.Checked
else:
return QtCore.Qt.Unchecked
else:
return QtSql.QSqlQueryModel.data(self, index, role)
def setData(self, index, value, role=QtCore.Qt.DisplayRole):
row = index.row()
if index.column() == self.column and role == QtCore.Qt.CheckStateRole:
if value.toBool():
self.checkboxes[row] = True
else:
self.checkboxes[row] = False
self.dataChanged.emit(index, index)
return True
else:
return False