python/pyside 在 qtreewidget 中使用自定义小部件

Posted

技术标签:

【中文标题】python/pyside 在 qtreewidget 中使用自定义小部件【英文标题】:python/pyside using a custom widget in a qtreewidget 【发布时间】:2013-03-02 19:59:54 【问题描述】:

使用 Python3 和 pyside。 我有一个 python 字典,我想使用 Qt 将其显示为树。我希望值是可编辑的,但不是键。我已经设法使用setItemWidget 实现了这一点,如下例所示:

#!/usr/bin/python3
# -*- coding: utf-8 -*-

import sys
from PySide import QtGui

def data_to_tree(parent, data):
    if isinstance(data, dict):
        parent.setFirstColumnSpanned(True)
        for key,value in data.items():
            child = QtGui.QTreeWidgetItem(parent)
            child.setText(0, key)
            data_to_tree(child, value)
    elif isinstance(data, list):
        parent.setFirstColumnSpanned(True)
        for index,value in enumerate(data):
            child = QtGui.QTreeWidgetItem(parent)
            child.setText(0, str(index))
            data_to_tree(child, value)
    else:
        widget = QtGui.QLineEdit(parent.treeWidget())
        widget.setText(str(data))
        parent.treeWidget().setItemWidget(parent, 1, widget)

app = QtGui.QApplication(sys.argv)

wid = QtGui.QTreeWidget()
wid.setColumnCount(2)
wid.show()

data = 
    'foo':'bar',
    'bar': ['f', 'o', 'o'],
    'foobar':0,

data_to_tree(wid.invisibleRootItem(), data)

sys.exit(app.exec_())

这可行,但它违背了文档的建议(静态内容),并且无法预先创建小部件(例如在单独的线程中)然后将其添加到树中。有没有更好的方法来实现我想要的?文档中提到了 QTreeView,但我没有找到任何示例/教程让我了解它如何帮助我在列中使用我自己的小部件。

【问题讨论】:

【参考方案1】:

您可能需要考虑 2 个选项:

您可以创建自己的类,它是QTreeWidget 的子类。这很简单,因为您只需按原样使用您拥有的方法并将其放入类中。但这并没有真正改变太多,除了在您的自定义小部件上调用它时看起来更“自然”。

另一种方法,也就是您在谈论文档时最可能引用的方法是模型/视图架构。

在这种情况下,您将不得不使用QTreeView 并创建自己的QTreeModel。在这里,视图完全不知道数据是什么,模型负责提供所有数据,并在视图准备好显示时通知视图。因此,您必须创建该对象并在数据准备好/更改时发出信号,以便更新视图。

要了解如何实现类似的东西,您可以查看 PySide 提供的示例。很可能您已经安装了它们,请查看site-packages/PySide/examples/itemviews/simpletreemodel

另外,请考虑查看 indexWidget 方法,以便您可以在需要的地方添加您的 QEditLine 并调用父级作为默认值。

【讨论】:

以上是关于python/pyside 在 qtreewidget 中使用自定义小部件的主要内容,如果未能解决你的问题,请参考以下文章

Python / Pyside 代码没有按顺序执行?

python pyside_ListViewSample

python pyside_sample

python hover_pyside.py

python pyside windowCheck

Python: PySide(PyQt)QMessageBox按钮显示中文