我想这样做的原因是允许用户使用 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 仅仅意味着不会有更多的子目录。
我已经看到了一些其他的实现,但是它们非常令人困惑,我不太明白它们的逻辑。这与我在这里提出的问题几乎重复,但尚未得到回答。我尝试过调整他的实现,但它(无论如何对我来说)很复杂,很难适应我的程序结构。