上一个问题是this。
已编辑以提供信息:
该模型表示一个字典,它们可以继承键值对之外的其他字典:
dict_of_dicts={
'dict1':{'k1':'v1', 'k2':'v2', 'k3':'v3', 'EXISTING_DICT':'dict2'},
'dict2':{'k4':'v4'},
'dict3':{'k5':'v5', 'k6':'v6'},
}
成为qlistview:
*dict1
------
dict2
-----
dict3
以及在qlistview中选择了dict1的qtableview:
k1 | v1
-------
k2 | v2
-------
k3 | v3
-------
dict2
有没有一种方法可以对模型进行排序,首先将继承的字典放在顶部,然后是字典元素?
dict2
-------
k1 | v1
-------
k2 | v2
-------
k3 | v3
如果我们动态引入新元素(我有办法在界面中引入新元素),那么不管顺序如何,它都会被排序?
我正在玩QStandardItemModel sort和setSortRole(Qt.CheckStateRole)
答案 0 :(得分:1)
以我的previous answer为基础,有必要使用QSortFilterProxyModel
,但我们必须使用角色QtCore.Qt.UserRole + 1000
,此外,我们还必须修改我将指出的部分评论:
# ...
class Widget(QtWidgets.QWidget):
def __init__(self, parent=None):
super(Widget, self).__init__(parent)
model = create_model_from_dict(dict_of_dicts, self)
self.tableview = TableView()
self.proxy_model = QtCore.QSortFilterProxyModel() # <---
self.proxy_model.setSourceModel(model) # <---
self.proxy_model.setSortRole(QtCore.Qt.UserRole + 1000) # <---
self.proxy_model.sort(0, QtCore.Qt.AscendingOrder) # <---
self.tableview.setModel(self.proxy_model) # <---
self.tableview.leftDoubleClicked.connect(self.handleSelectionChangedTV)
# ...
@QtCore.Slot(QtCore.QItemSelection)
def handleSelectionChangedLV(self, item):
ixs = item.indexes()
if ixs:
pix = self.proxy_model.mapFromSource(ixs[0]) # <---
self.tableview.setRootIndex(pix) # <---
model = self.tableview.model()
self.tableview.clearSpans()
for r in range(model.rowCount(self.tableview.rootIndex())):
index = model.index(r, 0, self.tableview.rootIndex())
if index.data(QtCore.Qt.UserRole + 1000):
self.tableview.setSpan(r, 0, 1, 2)
# ...