【发布时间】:2020-04-18 09:59:03
【问题描述】:
我已将数据插入到子类QAbstractListModel 中并用QListView 和QTableView 显示它
更改(删除一行)立即显示在QListView 中,但仅在选择表视图时才会显示在QTableView 中
sublcased 模型包含 setData 方法和 self.dataChanged.emit(index, index) 内部所以它应该更新自己。
为什么`QTableView 没有立即更新自己?
#!/usr/bin/env python
"""
minimum code to run a model view
"""
import sys
from PyQt5 import QtWidgets as qtw
from PyQt5 import QtCore as qtc
from PyQt5 import QtGui as qtg
class ViewModel(qtc.QAbstractListModel):
def __init__(self, input_data=None):
super().__init__()
self.input_data = input_data or []
# naming of rows ,columns static !!
def headerData(self, section, orientation, role):
if role == qtc.Qt.DisplayRole:
if orientation == qtc.Qt.Horizontal:
return "dude" # todo dynamic labeling
else:
return "leboswki" # todo dynamic labeling
def data(self, index, role):
if role == qtc.Qt.DisplayRole:
row = index.row() # == wie liste[row] der index
item = self.input_data[row]
return item
def rowCount(self, index): # parameter inside is needed !
return len(self.input_data)
def flags(self, index):
return qtc.Qt.ItemIsEditable | qtc.Qt.ItemIsSelectable | qtc.Qt.ItemIsEnabled
def setData(self, index, value, role):
if role == qtc.Qt.EditRole:
row = index.row()
if index.isValid():
self.input_data[row] = value
self.dataChanged.emit(index, index)
return True
else:
return False
def removeRows(self, position, rows, parent=qtc.QModelIndex()):
self.beginRemoveRows(parent, position, position + rows-1)
for i in range(rows):
value = self.input_data[position]
self.input_data.remove(value)
self.endRemoveRows()
return True
class MainWindow(qtw.QWidget):
def __init__(self):
super().__init__()
# View
list_view = qtw.QListView()
self.model = ViewModel(input_data=["text1", "text2", "text3", "text4"])
list_view.setModel(self.model)
table_view = qtw.QTableView()
table_view.setModel(self.model)
# widgets
self.deleate_row_button = qtw.QPushButton("deleate rows")
# layout
qvboxlayout = qtw.QVBoxLayout()
qvboxlayout.addWidget(list_view)
qvboxlayout.addWidget(table_view)
qvboxlayout.addWidget(self.deleate_row_button)
self.setLayout(qvboxlayout)
self.show()
# function
self.deleate_row_button.clicked.connect(lambda: self.model.removeRows(-1, 1))
if __name__ == '__main__':
app = qtw.QApplication(sys.argv)
w = MainWindow()
sys.exit(app.exec_())
【问题讨论】: