php 一维数组按条件转换成二维数组

如:
array(4) {
[0] => array(4) {
["id"] => string(1) "2"
["sort"] => string(1) "2"
["navname"] => string(12) "常见问题"
["parentsid"] => string(1) "0"
}
[1] => array(4) {
["id"] => string(1) "3"
["sort"] => string(1) "3"
["navname"] => string(12) "配置接口"
["parentsid"] => string(1) "0"
}
[2] => array(4) {
["id"] => string(1) "4"
["sort"] => string(1) "4"
["navname"] => string(12) "问题一"
["parentsid"] => string(1) "2"
}
[3] => array(4) {
["id"] => string(1) "4"
["sort"] => string(1) "4"
["navname"] => string(12) "配置接口一"
["parentsid"] => string(1) "3"
}}

需要将id和parentid匹配,匹配对应的将含有parentid的作为子级,在一级数组中添加一个键值形成:
[0] => array(4) {
["id"] => string(1) "2"
["sort"] => string(1) "2"
["navname"] => string(12) "常见问题"
["parentsid"] => string(1) "0"
["subnav"]=>array(4){
["id"] => string(1) "4"
["sort"] => string(1) "4"
["navname"] => string(12) "问题一"
["parentsid"] => string(1) "2"
}

谢谢

//根据你的需求,我写了个测试程序,你整理下就可以用了
$array = array(
array('id'=>1,"parentsid"=>0),
array('id'=>2,"parentsid"=>0),
array('id'=>3,"parentsid"=>2),
array('id'=>4,"parentsid"=>2),
array('id'=>5,"parentsid"=>1),
array('id'=>6,"parentsid"=>1)
);

$newArray = array();

foreach($array as $row){
if($row['parentsid'] == 0){
$newArray[] = $row;
}
}

foreach($array as $row){
foreach($newArray as $key=>$newRow){
if($row['parentsid'] == $newRow['id']){
$newArray[$key]['subnav'][] = $row;
}
}
}

温馨提示:答案为网友推荐,仅供参考
第1个回答  2014-10-20
写个函数,也是来自于tp官方
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;
}
然后定义一维数组为$list,然后 print_r(list_to_tree($list,"id","parentsid","subnav"));本回答被网友采纳
第2个回答  2014-10-20
function made_array($parent_id){
$str=array();
$arrays = get_arrays($parent_id);
foreach($arrays as $arr){
if(made_array($arr['id'])){
$arr['subnav']=made_array($arr['id']);
}
$str[]=$arr;
}
return $str;
}
function get_arrays($parent_id){
//返回parentsid=$parent_id的数组
}
made_array(0)就是结果
第3个回答  2014-10-20
写个递归方法就可以了。追问

我就是不太清楚怎么写这个递归方法,有没有简单例子,或者你能否帮我写下,我参考下,谢谢

追答$d = array(
  '0' => array (
    'id' =>  "2",
    'sort' =>  "2",
    'navname' =>  "常见问题",
    'parentsid' =>  "0",
  ),
  '1' => array (
    'id' =>  "3",
    'sort' =>  "3",
    'navname' =>  "配置接口",
    'parentsid' =>  "0",
  ),
  '2' => array (
    'id' =>  "4",
    'sort' =>  "4",
    'navname' =>  "问题一",
    'parentsid' =>  "2",
  ),
 '3' => array (
   'id' =>  "4",
   'sort' =>  "4",
   'navname' =>  "配置接口一",
   'parentsid' =>  "3",
 ),
);


$data = build_tree($d);
print_r($data);

function build_tree($dat,$parentsid='0'){
$rs = array();
foreach($dat as $val){
if($val['parentsid']==$parentsid){
$subnav = build_tree($dat,$val['id']);
if($subnav){
$val['subnav'] = $subnav;
}
array_push($rs,$val);
}
}
return $rs;
}

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网