0

我对 python 很陌生,我觉得这是一个高级问题,考虑到它可能超出了 Stack Exchange 的范围。请多多包涵。

我有一个 QTreeWidget 和 QStackedWidget。我已经使用元组填充了 QTreeWidget

TreeList = ({

    'Header1': ((
        'Item11',
        'Item12',
    )),

    'Header2': ((
        'Item21',
        'Item22'
    ))
})

for key, value in TreeList.items():
    root = QTreeWidgetItem(self.QTreeWidget, [key])
    for val in value:
        root.addChild(QTreeWidgetItem([val]))

我想使用这个相同的元组来填充一个 QStackedWidget 与 QTreeWidget 对应的页面,并在同一个循环中建立信号和槽。我试过使用:

for key in TreeList['Item1']:
    page = QWidget()
    page.setObjectName(key)
    self.QStackedWidget.addWidget(page)
    print(self.QStackedWidget)

但是所有对象都指向相同的十六进制值,我认为这意味着它们不是唯一的。也许我需要增加索引?在任何一种情况下,我都无法弄清楚如何在执行此操作时生成信号和插槽,因为它们是动态创建的,我需要唯一但可预测的名称。

这个想法是,通过简单地向元组添加一个新的类别或项目,QTreeView、QStackedWidget 和信号/插槽都在运行时生成,而无需修改元组之外的任何源代码。

实现这一目标的最佳方法是什么?

对不起,如果这太多了,但我认为这可能是一个很好的问题,以防其他人在以后尝试同样的事情。

编辑:我正在使用 Python 3.6 和 PyQt5

4

1 回答 1

1

思路是把 的索引和 关联QStackedWidget起来QTreeWidgetItem,所以我们可以用 的setData()方法QTreeWidgetItem保存索引,然后用data()方法恢复:

import sys

from PyQt5.QtWidgets import *
from PyQt5.QtCore import *

class Widget(QWidget):
    def __init__(self, *args, **kwargs):
        QWidget.__init__(self, *args, **kwargs)
        self.tree = QTreeWidget(self)
        self.stack = QStackedWidget(self)
        lay = QHBoxLayout(self)
        lay.addWidget(self.tree)
        lay.addWidget(self.stack)

        for key, value in TreeList.items():
            root = QTreeWidgetItem(self.tree, [key])
            for val in value:
                item = QTreeWidgetItem([val])
                root.addChild(item)
                widget = QLabel(val,  self)
                ix = self.stack.addWidget(widget)
                item.setData(0, Qt.UserRole, ix)
        self.tree.expandAll()
        self.tree.itemClicked.connect(self.onItemClicked)

    def onItemClicked(self, item, column):
        val = item.data(0, Qt.UserRole)
        if val is not None:
            self.stack.setCurrentIndex(val)

TreeList = ({

    'Header1': ((
        'Item11',
        'Item12',
    )),

    'Header2': ((
        'Item21',
        'Item22'
    ))
})

if __name__ == '__main__':
    app = QApplication(sys.argv)
    w = Widget()
    w.show()
    sys.exit(app.exec_())
于 2017-12-01T20:08:45.320 回答