php 使用&引用 巧妙实现层级树

<?php

$a = array(

    array('node_id'=>1,'pid'=>0),

    array('node_id'=>2,'pid'=>1),

    array('node_id'=>3,'pid'=>1),

    array('node_id'=>4,'pid'=>2),

    array('node_id'=>5,'pid'=>3),

    array('node_id'=>6,'pid'=>5),

    array('node_id'=>7,'pid'=>8),

    array('node_id'=>8,'pid'=>9),

    array('node_id'=>9,'pid'=>0),

);

$tmp = array();

foreach($a as $k=>$v){

    $tmp[$v['node_id']] = &$a[$k];

}

$tree = array();

foreach($a as $k=>$v){

    if(!empty($v['pid'])){

        if(!$tmp[$v['pid']]) continue;

        $t = &$tmp[$v['pid']];

        $t['childrens'][] = &$a[$k];

    }else{

        $tree[] = &$a[$k];

    }

}

print_r($tree);exit;

输出结果:


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 easyexcel 导出层级,首先需要准备好数据。数据应该是一个包含父子关系的形结构,每个节点应该至少包含以下属性:节点 ID、节点名称、父节点 ID。 接下来,可以使用 easyexcel 的 @ExcelIgnore 注解来忽略父节点 ID 属性的导出,并使用 @ExcelProperty 注解来指定其他属性的导出顺序和列名。示例代码如下: ```java public class TreeNode { @ExcelProperty("节点ID") private Long id; @ExcelProperty("节点名称") private String name; @ExcelIgnore private Long parentId; // getter 和 setter 方法省略 } ``` 然后,可以使用递归的方式将形结构转换成列表,其中每个节点的子节点应该排在该节点的下方。示例代码如下: ```java public List<TreeNode> flattenTree(List<TreeNode> tree, Long parentId) { List<TreeNode> flattened = new ArrayList<>(); for (TreeNode node : tree) { if (node.getParentId().equals(parentId)) { flattened.add(node); flattened.addAll(flattenTree(tree, node.getId())); } } return flattened; } ``` 最后,可以使用 easyexcel 的 ExcelWriter 类来导出数据。示例代码如下: ```java public void exportTree(List<TreeNode> tree, OutputStream outputStream) { List<TreeNode> flattened = flattenTree(tree, null); try (ExcelWriter writer = EasyExcel.write(outputStream).build()) { WriteSheet sheet = EasyExcel.writerSheet().build(); writer.write(flattened, sheet); } } ``` 这样就可以将层级导出成一个 Excel 文件了。需要注意的是,如果形结构比较大,递归可能会导致栈溢出,可以使用迭代或其他方式来优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值