在Python中以树形显示列表列表

时间:2018-12-14 18:09:35

标签: python list tree

我想定义一个函数,将具有常见组件的列表列表打印为树。

例如,

lst = [[1, 2, 'a'], [1, 2, 'b'], [1, 1, 'a'], [1, 1, 'b'], [2, 2, 'a']]
build_tree(lst)

应打印:

1
    1
        a
        b
    2
        b
2
    2
        a

我写了以下代码。

def build_tree(lst):
    if len(lst[0]) == 1:
        for e in lst:
            return str(e[0])
    current = lst[0][0]
    seen = []
    tree = ''
    for e in lst:
        if e[0] != current:
            tree += str(current)
            tree += build_tree(seen)
            current = e[0]
            seen = []
        seen.append(e[1:])
    return tree

但是返回的结果是胡说八道。

1 个答案:

答案 0 :(得分:1)

解决此问题的一种方法是将列表更改为树结构,然后遍历该树以构建数据的字符串表示形式

from collections import defaultdict

tree = lambda: defaultdict(tree)

lst = [[1, 2, 'a'], [1, 2, 'b'], [1, 1, 'a'], [1, 1, 'b'], [2, 2, 'a']]


def make_tree(lst):
    d = tree()    
    for x in lst:
        curr = d
        for item in x:
             curr = curr[item]
    return d

d = make_tree(lst)

def make_strs(d, indent=0):
     strs = []
     for k, v in d.items():
         strs.append('    ' * indent + str(k))
         strs.extend(make_strs(v, indent+1))
     return strs

def print_tree(d):
    print('\n'.join(make_strs(d)))

print_tree(d)

打印

1
    2
        a
        b
    1
        a
        b
2
    2
        a
相关问题