PySide2 QListView QTableView同步问题

时间:2019-01-03 07:58:03

标签: python model-view-controller qtableview qlistview pyside2

这是与python / PySide2接口相关的问题,正如我尝试过的,我无法使其同步(QListView和QTableView)。

我将尝试简化它,而不是解释整个复杂的问题,因为QT中充满了表格内容,这会变得更大……

试想像这样具有一个数据结构(我想是模型):

dict_of_dicts={
'dict1':{'k1':'v1', 'k2':'v2', 'k3':'v3'},
'dict2':{'k4':'v4'},
'dict3':{'k5':'v5', 'k6':'v6', 'k7':'v7'},
}

我想要一个包含两个部分的表单(或对话框):

1)在表单的左侧,具有一个QListView以可视化以下内容:

*dict1
------
dict2
-----
dict3

注意:

  • dict1中的星号表示已选中。

  • 连字符只是在行之间分隔。

2)在表单的右侧,使QTableView显示以下内容:

k1 | v1
-------
k2 | v2
-------
k3 | v3

注意:

  • 连字符只是在行之间分隔。

  • 管道只是用来表示列的分隔。

  • 每次在QListView中选择另一个元素时,QTableView必须更改为原始数据结构指示的元素。

我相信对于大多数人来说这确实很容易,但是我只是从UI内容和MVC开始。

1 个答案:

答案 0 :(得分:0)

您必须创建一个具有树结构的模型,在该模型中可以看到相关性,对于QListView,它将显示根项,对于QTableView,将显示叶子,并且将具有rootIndex QListView的选定QModelIndex。出于教育目的,我将在QTreeView中显示树的模型。

from PySide2 import QtCore, QtGui, QtWidgets

dict_of_dicts={
    'dict1':{'k1':'v1', 'k2':'v2', 'k3':'v3'},
    'dict2':{'k4':'v4'},
    'dict3':{'k5':'v5', 'k6':'v6', 'k7':'v7'},
}

def create_model_from_dict(d, parent=None):
    model = QtGui.QStandardItemModel(0, 2, parent)
    for k, v in dict_of_dicts.items():
        it = QtGui.QStandardItem(k)
        model.appendRow(it)
        for k_, v_ in v.items():
            it.appendRow([QtGui.QStandardItem(k_), QtGui.QStandardItem(v_)])
    return model

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 = QtWidgets.QTableView()
        self.tableview.setModel(model)

        self.listview = QtWidgets.QListView()
        self.listview.setModel(model)
        self.listview.selectionModel().selectionChanged.connect(self.handleSelectionChanged)
        self.listview.selectionModel().select(model.index(0, 0), QtCore.QItemSelectionModel.Select)

        self.treeview = QtWidgets.QTreeView()
        self.treeview.setModel(model)
        self.treeview.expandAll()

        hlay = QtWidgets.QHBoxLayout(self)
        hlay.addWidget(self.listview)
        hlay.addWidget(self.tableview)
        hlay.addWidget(self.treeview)

    @QtCore.Slot(QtCore.QItemSelection)
    def handleSelectionChanged(self, item):
        ixs = item.indexes()
        if ixs:
            self.tableview.setRootIndex(ixs[0])

if __name__ == '__main__':
    import sys
    app = QtWidgets.QApplication(sys.argv)
    w = Widget()
    w.show()
    sys.exit(app.exec_())

enter image description here

enter image description here

enter image description here