我知道http_build_query()和parse_str()是这类问题的更好解决方案,但我无法更改我正在处理的特定项目中的数据结构,所以我试图通过创建来简化一些事情来自数据库存储字符串的大型 3d 关联数组。
有人可以帮我做这个函数递归吗?我希望它采取这样的方式:
explode3D( $separators = array('|',','),
$string = "val1,val2|val1,val2,val3",
$keys = "cat1,item1,item2|cat2,item1,item2,item3"
);
并返回这样的东西
Array (
'cat1' => Array('item1'=>'val1', 'item2'=>'val2'),
'cat2' => Array('item1'=>'val1', 'item2'=>'val2', 'item3'=>'val3')
)
这是到目前为止的功能:
function explode3D($separators,$string,$keys=0){
$res = array();
if(is_array($separators)){//MULTI DIMENSION MODE: (unfinished!!)
//help needed here//
}else{//SINGLE DIMENSION MODE:
$vals = explode($separators,$string);
if($keys === 0){ //NO KEYS:
$res = $vals;
}else if($keys === 1){//ALTERNATE ROWS ARE KEYS:
$key = '';
for($i=0; $i<sizeof($vals); $i++){
if ($i++ % 2 == 1 ){ //every second element:
$key = $vals[$i]; //save the key
}else{
$res[$key] = $vals[$i]; //set the saved key = value
}
}
}else{ //GET KEYS FROM $keys ARRAY:
if(is_string($keys)){ //explode keys string if necessary (using $separators)
$keys = explode3D($separators,$keys);
}
for($i=0; $i<sizeof($vals); $i++){
$res[$keys[$i]] = $vals[$i];
}
}
}
return($res);
}