/**
* 转换成树行结构的二维数组
* @param array $list 要转换的二维结果集
* @param string $id 主键标记字段
* @param string $pid parent标记字段
* @param string $child child标记字段
* @return array
*/
function list_to_tree($list,$pk='id',$pid='parentid',$child='son_list',$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
$parantId = $data[$pid];
if ($root == $parantId) {
$tree[] = &$list[$key];
} else {
if (isset($refer[$parantId])) {
$parent = &$refer[$parantId];
$parent[$child][] = &$list[$key];
}
}
}
}
return $tree;
}