这是一个怪物,但它会做你想做的事。在递归函数中使用 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);