考虑一个任意形式和嵌套深度的关联数组,例如:
$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、floats、bool 和字符串(,它将返回一个数组$return['path']
并$return['value']
。这很快就马虎了!在 PHP 中是否有更好的方法可以做到这一点?我假设调用对象和对象不会在数组中传递,尽管任何处理这种可能性的解决方案都是最好的。此外,我假设输入数组在元素名称中没有/
字符,但考虑这一点可能是谨慎的!请注意,输入数组可以嵌套到 8 层或更多层深!
递归确实是你能够处理这个问题的唯一方法,但这里有一个简单的版本开始:
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;
}
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);
全部由您将其放置在数组中。