所以这是输入:
$in['a--b--c--d'] = 'value';
所需的输出:
$out['a']['b']['c']['d'] = 'value';
有什么想法吗?我没有运气就试过以下代码......
$in['a--b--c--d'] = 'value';
// $str = "a']['b']['c']['d";
$str = implode("']['", explode('--', key($in)));
${"out['$str']"} = 'value';
答案 0 :(得分:8)
这似乎是递归的主要候选人。
基本方法如下:
下面的递归就是这样,在每次调用期间创建一个新数组,列表中的第一个键被指定为新值的键。在下一步中,如果有剩余的键,则重复该过程,但是当没有剩下键时,我们只返回该值。
$keys = explode('--', key($in));
function arr_to_keys($keys, $val){
if(count($keys) == 0){
return $val;
}
return array($keys[0] => arr_to_keys(array_slice($keys,1), $val));
}
$out = arr_to_keys($keys, $in[key($in)]);
对于您的示例,上面的代码将评估为与此等效的内容(但适用于任意数量的--
个分隔项的一般情况):
$out = array($keys[0] => array($keys[1] => array($keys[2] => array($keys[3] => 'value'))));
或者用更明确的术语来构建以下内容:
$out = array('a' => array('b' => array('c' => array('d' => 'value'))));
允许您通过所需的索引访问每个子数组。
答案 1 :(得分:1)
$temp = &$out = array();
$keys = explode('--', 'a--b--c--d');
foreach ($keys as $key) {
$temp[$key] = array();
$temp = &$temp[$key];
}
$temp = 'value';
echo $out['a']['b']['c']['d']; // this will print 'value'
在上面的代码中,我为每个键创建一个数组,并使用$ temp来引用最后创建的数组。当我用完钥匙时,我用实际值替换最后一个数组。 请注意,$ temp是对最后创建的,嵌套最多的数组的引用。