考虑任意形式和嵌套深度的关联数组,例如:
$someVar = array(
'name' => 'Dotan',
'age' => 35,
'children' => array(
0 => array(
'name' => 'Meirav',
'age' => 6,
),
1 => array(
'name' => 'Maayan',
'age' => 4,
)
),
'dogs' => array('Gili', 'Gipsy')
);
我想将其转换为路径和值的关联数组:
$someVar = array(
'name' => 'Dotan',
'age' => 35,
'children/0/name' => 'Meirav',
'children/0/age' => 6,
'children/1/name' => 'Maayan',
'children/1/age' => 4,
'dogs/0' => 'Gili',
'dogs/1' => 'Gipsy'
);
我开始编写一个递归函数,对于数组元素将递归,对于非数组元素(int,float,bools和strings)返回一个数组$return['path']
和$return['value']
。这快速变得邋! 有没有更好的方法在PHP中执行此操作?我会假设callables和对象不会在数组中传递,尽管处理这种可能性的任何解决方案都是最好的。另外,我假设输入数组在元素名称中没有/
字符,但考虑到这一点可能是谨慎的! 请注意,输入数组可以嵌套为深度为8或更深的级别!
答案 0 :(得分:3)
递归真的是你能够处理这个问题的唯一方法,但这里有一个简单的版本:
function nested_values($array, $path=""){
$output = array();
foreach($array as $key => $value) {
if(is_array($value)) {
$output = array_merge($output, nested_values($value, (!empty($path)) ? $path.$key."/" : $key."/"));
}
else $output[$path.$key] = $value;
}
return $output;
}
答案 1 :(得分:1)
function getRecursive($path, $node) {
if (is_array($node)) {
$ret = '';
foreach($node as $key => $val)
$ret .= getRecursive($path.'.'.$key, $val);
return $ret;
}
return $path.' => '.$node."\n";
}
$r = getRecursive('', $someVar);
print_r($r);
所有你把它放在一个数组中。