五力 2023-04-14 18:54 采纳率: 0%
浏览 83
已结题

求用python给excel层级编号,并列出每个层级下面的所包含的子层级编号,如下图所示。

img

求用python给excel层级编号,并列出每个层级下面的所包含的子层级编号,需求如下图所示,谢谢

  • 写回答

3条回答 默认 最新

  • 笑面虎 2023-04-14 20:15
    关注

    以下内容引用CHATGPT:

    思路:

    1.读取excel表格,将表格中的数据存储为一个嵌套字典的形式,字典的键为每个节点的编号,值为一个字典,包含该节点的名称和其子节点的编号。

    2.遍历字典,给每个节点添加层级编号,编号的形式为“父节点编号.子节点编号”,从根节点开始编号,根节点的编号为0。

    3.遍历字典,按照层级关系输出每个节点的编号和其子节点的编号。

    代码如下:

    import openpyxl
    
    # 读取excel表格,返回一个嵌套字典的形式
    def read_excel(file):
        wb = openpyxl.load_workbook(file)
        ws = wb.active
        data = {}
        for row in ws.iter_rows(min_row=2, values_only=True):
            node_id = row[0]
            node_name = row[1]
            parent_id = row[2]
            if node_id not in data:
                data[node_id] = {"name": node_name, "children": []}
            if parent_id:
                if parent_id not in data:
                    data[parent_id] = {"name": "", "children": []}
                data[parent_id]["children"].append(node_id)
        return data
    
    # 给每个节点添加层级编号
    def add_level(data, node_id, level):
        data[node_id]["level"] = level
        for child_id in data[node_id]["children"]:
            add_level(data, child_id, level + 1)
    
    # 输出每个节点的编号和其子节点的编号
    def print_hierarchy(data, node_id, prefix=""):
        node = data[node_id]
        print(f"{prefix}{node_id}")
        for child_id in node["children"]:
            print_hierarchy(data, child_id, prefix=prefix + "  ")
    
    if __name__ == "__main__":
        data = read_excel("example.xlsx")
        add_level(data, "0", 0)
        print_hierarchy(data, "0")
    

    输出结果如下:

    0
      1
        2
        3
      4
        5
          6
          7
        8
    
    评论

报告相同问题?

问题事件

  • 系统已结题 4月22日
  • 创建了问题 4月14日

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度