如何用PHP将一维数组转换为三层嵌套的树状结构?(嵌套.树状.数组.转换为.如何用...)
本文探讨如何高效地将PHP一维数组转换为三层嵌套的树状结构。给定一个包含项目名称、型号和位置信息的数组,目标是将其转换为树形结构,项目名称作为一级节点,型号为二级节点,位置为三级节点。
初始数组:
$arr = [ ['name' => "项目1", 'model' => "金", 'location' => '苏州'], ['name' => "项目1", 'model' => "银", 'location' => '上海'], ['name' => "项目2", 'model' => "铜", 'location' => '北京'], ['name' => "项目2", 'model' => "铜", 'location' => '深圳'], ];
目标树状结构:
$target = [ [ 'name' => "项目1", 'child' => [ ['model' => "金", 'child' => [['location' => '苏州']]], ['model' => "银", 'child' => [['location' => '上海']]], ] ], [ 'name' => "项目2", 'child' => [ ['model' => "铜", 'child' => [['location' => '北京'], ['location' => '深圳']]], ] ], ];
之前的解决方案过于复杂。我们可以采用更简洁、易于理解的方法,利用循环和条件判断来构建树状结构:
$result = []; foreach ($arr as $item) { $name = $item['name']; $model = $item['model']; $location = $item['location']; // 查找或创建项目名称节点 $nameIndex = array_search($name, array_column($result, 'name')); if ($nameIndex === false) { $result[] = ['name' => $name, 'child' => []]; $nameIndex = count($result) - 1; } // 查找或创建型号节点 $modelIndex = array_search($model, array_column($result[$nameIndex]['child'], 'model')); if ($modelIndex === false) { $result[$nameIndex]['child'][] = ['model' => $model, 'child' => []]; $modelIndex = count($result[$nameIndex]['child']) - 1; } // 添加位置节点 $result[$nameIndex]['child'][$modelIndex]['child'][] = ['location' => $location]; } print_r($result); // 输出转换后的树状结构
这段代码首先初始化一个空数组 $result。然后,它迭代原始数组 $arr 中的每个项目。对于每个项目,它查找是否存在对应的项目名称和型号节点。如果不存在,则创建新的节点。最后,它将位置信息添加到相应的型号节点下。 这种方法更清晰,也更容易维护。
这种方法避免了嵌套的 array_map 和 array_reduce,使其更易于理解和调试。 它直接操作数组,效率也更高。 选择适合自己项目的方法,并根据实际情况调整代码。
以上就是如何用PHP将一维数组转换为三层嵌套的树状结构?的详细内容,更多请关注知识资源分享宝库其它相关文章!