qq_39965973 2021-04-15 21:15 采纳率: 0%
浏览 68
已结题

python 多个全路径列表转换为pyecharts tree图所需格式

请问如何将:

item1=['e0', 'e1', 'e7', 'e11']
item2=['e0', 'e1', 'e7', 'e8', 'e9']
item3=['e0', 'e1', 'e2']


转换为pyecharts tree图所需格式:

    data = [
        {"name": "e0",
         "children": [
             {"name": "e1",
              "children": [
                  {"name": "e7",
                   "children": [
                       {"name": "e90"},
                       {"name": "e8",
                        "children": [
                            {"name": "e9"
                             }]}
                   ]},
                  {"name": "e2"},
              ]},
         ],
         }
    ]

 画图

import json

from pyecharts.charts import Page, Tree

def tree_base(data):
    tree = (
        Tree()
            .add("", data)
            .set_global_opts(title_opts=opts.TitleOpts(title="Tree-基本示例"))
    )
    tree.render('./map1.html')
    return tree

tree_base(data)

如果可以的话,能否用以下列表实现:

​

item1=['e0', 'e1', 'e7', 'e11']
item2=['e1', 'e7', 'e8', 'e9']
item3=['e1', 'e2']


[点击并拖拽以移动]
​

效果如图:

 

  • 写回答

4条回答 默认 最新

  • 关注
    item1=['e0', 'e1', 'e7', 'e90']
    item2=['e1', 'e7', 'e8', 'e9']
    item3=['e1', 'e2']
    
    lis = [item1,item2,item3]
    tdict = {}
    data = []
    for li in lis:
        p = None
        for x in li:
            if x in tdict:
                p = tdict[x]
                continue
            d = {"name": x}
            tdict[x] = d
            if p:
                p.setdefault("children",[]).append(d)
            else:
                data.append(d)
            p = d
    
    import json
    print(json.dumps(data,indent=4))
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 高价求中通快递查询接口
  • ¥15 解决一个加好友限制问题 或者有好的方案
  • ¥15 关于#java#的问题,请各位专家解答!
  • ¥15 急matlab编程仿真二阶震荡系统
  • ¥20 TEC-9的数据通路实验
  • ¥15 ue5 .3之前好好的现在只要是激活关卡就会崩溃
  • ¥50 MATLAB实现圆柱体容器内球形颗粒堆积
  • ¥15 python如何将动态的多个子列表,拼接后进行集合的交集
  • ¥20 vitis-ai量化基于pytorch框架下的yolov5模型
  • ¥15 如何实现H5在QQ平台上的二次分享卡片效果?