好的,所以在使用您解析 ini 文件后,parse_ini_file
您应该得到与此类似的数组(当使用进程部分 TRUE 时):
$first_ini = array(
'MAIN' => array(
'lib' => 'lib_folder',
'bin' => 'bin_folder',
'usr' => 'usr_folder',
'etc' => 'etc_folder'
)
);
$second_ini = array(
'alib' => 1,
'abin' => 0,
'ausr_other' => 'usr/tree'
);
$master_ini = array(
'lib' => 'lib_other',
'abin' => 1
);
然后您可以使用这个简单的功能(未测试):
function combine_master_with_slave($master, $slave) {
foreach($slave as $key => $val) { // we will loop through slave array
if(is_array($val)) { // if the value is an array use recursion
$slave[$key] = combine_master_with_slave($master, $val);
}
if(isset($master[$key])) { // if master array contains the same key as a slave array, replace it's value by the master's one
$slave[$key] = $master[$key];
}
}
return $slave; // finaly return the processed slave array
}
但我真的不确定这是否可行,也许它需要一些轻微的修改......
此外,您必须调用此函数的次数是您拥有的从阵列数量的倍数,或者换句话说,您必须为每个从阵列调用此函数。
这应该适用于任何子数组级别,即使它是 [ [ [ [ [ [][][][] ] ] ] ] ]。