/**
* 数据集转tree
* @param array $list 要转换的数据集
* @param string $pid parent标记字段
* @param string $level level标记字段
* @return array
*/
function list_to_tree($list, $pk='id', $pid = 'pid', $child = '_child', $root = 0) {
// 创建Tree
$tree = array();
if(is_array($list)) {
// 创建基于主键的数组引用
$refer = array();
foreach ($list as $key => $data) {
$refer[$data[$pk]] =& $list[$key];
}
foreach ($list as $key => $data) {
// 判断是否存在parent
$parentId = $data[$pid];
if ($root == $parentId) {
$tree[] =& $list[$key];
}else{
if (isset($refer[$parentId])) {
$parent =& $refer[$parentId];
$parent[$child][] =& $list[$key];
}
}
}
}
return $tree;
}
php实现无限极分类查询不用递归实现
最新推荐文章于 2023-03-28 16:39:57 发布
本文介绍了一种将数据集转换为树形结构的方法,通过使用递归算法,该方法可以将具有层级关系的数据集转换成易于理解和操作的树形结构。此方法适用于多种场景,如文件系统的目录结构展示、组织架构图的构建等。

334

被折叠的 条评论
为什么被折叠?



