-1

我想这样做的原因是允许用户使用 a 创建文件树QTreeWidget,然后我想将该树提取到嵌套dict结构中,并以某种方式保存它。我考虑过使用txt文件和eval方法将所有保存的方案简单地加载到某个数组或另一个字典中,其中键是方案的名称,因此用户可以简单地选择一个方案或根据需要对其进行编辑。这自然导致我必须在用户选择编辑后将保存dict的内容转换回。QTreeWidget

现在虽然这是我的问题。

我已经能够QTreeWidget使用递归函数成功导航。我挣扎的是创建嵌套dict.

以下是我到目前为止提出的内容:

def tree_to_dict(self, parent, key):
    for i in range(parent.childCount()):
        cur_par = parent.child(i)
        if cur_par.childCount() == 0:
            try:
                if type(self.scheme[key]) is dict :
                    self.scheme[key][cur_par.text(0)] = 'E'
            except KeyError:
                key = cur_par.text(0)
                self.scheme[key] = 'E'
        else:
            key = cur_par.text(0)
            self.scheme[key] = {}
            self.tree_to_dict(cur_par, key)

我知道这是错误的。这就是我需要帮助的原因。

上面的代码生成如下dict形式QTreeWidget

a
b
    a
c

{'a':'E', 'b':{'a':'E', 'c':'E'}}

但它应该是:

{'a':'E', 'b':{'a':'E'}, 'c':'E'}

E 仅仅意味着不会有更多的子目录。

我已经看到了一些其他的实现,但是它们非常令人困惑,我不太明白它们的逻辑。与我在这里提出的问题几乎重复,但尚未得到回答。我尝试过调整他的实现,但它(无论如何对我来说)很复杂,很难适应我的程序结构。

4

1 回答 1

1

您的实现可能比要求的复杂。

由于每个项目都是键,因此您需要递归迭代并返回该键的值。

如果该项目没有子项,它将返回“E”,否则它将使用给定的子项再次调用该函数,依此类推。
该函数不需要 key 参数,因为它将由递归调用创建。

    def tree_to_dict(parent):
        childCount = parent.childCount()
        if not childCount:
            return 'E'
        content = {}
        for row in range(childCount):
            child = parent.child(row)
            content[child.text(0)] = tree_to_dict(child)
        return content

然后,只需使用invisibleRootItem().

于 2021-10-31T12:27:56.173 回答