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