0

我有一个由 PHP 生成的数组

array(
  array(
  'name'=>'node1',
  'id' => '4'
   ),
  array(
  'name'=>'node2'
  'id'=>'7'
  )
)

我正在尝试将一个数组添加到一个特定的 id (所以我们说 id 4)

'children'=>
        array(
          array('name'=>'node2','id'=>'5'),
          array('name'=>'node3','id'=>'6')
        )

那么它看起来像

array(
  array(
  'name'=>'node1',
  'id' => '4'
  'children'=>
        array(
          array('name'=>'node2','id'=>'5'),
          array('name'=>'node3','id'=>'6')
        )
   ),
  array(
  'name'=>'node2'
  'id'=>'7'
  )
)

但我似乎无法找到搜索多维数组并将多维数组添加到该数组的方法。

有什么帮助吗?

4

3 回答 3

2

使用foreach循环遍历数组(确保也获得键),检查值,如果需要添加并在找到时中断。

foreach($array as $k=>$v) {
    if( $v['id'] == 4) {
        $array[$k]['children'] = array(...);
        break;
    }
}
于 2012-06-14T02:55:32.370 回答
0

这是一个怪物,但它会做你想做的事。在递归函数中使用 push 失败,因为引用在第二次函数调用后被破坏,所以如果你不知道关键有多深,可以选择使用任意数量的循环和希望最好的循环,导入变量和使用eval 推送新值,或拉开并重建数组。我选择了评估。您想要的内容的描述与推送值略有不同,因为您正在寻找数组中的键值对,而不是数组。此函数查找键值对并将您想要的任何内容添加为同级,如果未指定值,则将值作为同级添加到匹配的第一个键。如果未指定 pushval,它将返回指向匹配键/键值的键链。

$ref_array是要修改的多数组, $key是您要查找的键, $val是您要查找的 $newkey键的值,是将引用新值的新键, $pushval是要索引的新值$newkey

不要为参数传递$val_array参数。它仅用于递归调用。这是函数如何区分新调用和递归调用的方式,也是函数如何在不中断传递引用的情况下找到键值的方式。

function deepPush(&$ref_array, $key, $val=null, $newkey=null, $pushval=null, $val_array=null)
{
    static $r, $keys;

    #reset static vars on first call
    if(!$val_array){ $r = 0; $keys = array();}
    #cap recursion
    if($r > 100){ trigger_error('Stack exceeded 100'); return;}
    #init val_array
    $val_array = ($r) ? $val_array : $ref_array;
    #specified search value???
    $search_val = ($val!==null && !in_array($val, $val_array)) ? true : false;
    if(!array_key_exists($key, $val_array) || $search_val) {
    $i=0;foreach($val_array as $k=>$v){
            if(gettype($v) == 'array') {
                if($i>0){/*dead-end*/array_pop($keys); /*keep recusion accurate*/$r-=$i;}
                $keys[] = $k;/*build keychain*/
                $r++; $i++; /*increment recursion, iteration*/
                if(deepPush($ref_array, $key, $val, $newkey, $pushval, $v)){ /*close stack on 1st success*/return $keys;}
            }//if
        }//foreach
    }//if
    else{
        if($pushval === null){return $keys;}
        #add $newkey to the keychain
        $keys[] = $newkey;
        #process $pushval based on type
        $pushval = (gettype($pushval) == 'string') ? sprintf("'%s'", $pushval) : var_export($pushval, true);

        #link keys together to form pointer
        $p = '$ref_array';
        for($j=0,$c=count($keys); $j<$c; $j++) {
            $k = $keys[$j];
            $p .= "['$k']";
        }//for

        #concat the value to be pushed
        $p .= sprintf("= %s;",$pushval);
        #push it
        eval($p);

        $keys = array();
        return true;

    }//else

}

deepPush($array, 'id', 4, 'children', $addThis);
于 2012-06-14T23:51:37.870 回答
0
foreach($a as $k => $v)
{
  if(is_array($v))
  {
   foreach($v as $ke => $va)
   {
    if($ke == 'children')
    {
     ......
    }
   }
 }
}
于 2012-06-14T05:16:20.857 回答