$arr = array_merge($arr1, $arr2, $arr3);
$out = array();
$cnt = 0;
foreach ($arr as $key => $value){
$date = explode('/', $value[0]);//Change date format
$dex = strtotime($date[1].'/'.$date[0].'/'.$date[2].' '.$value[1]);
$head = (array_key_exists($dex, $out)) ? $out[$dex] : array_slice($value, 0, 2);
$out[$dex] = array_merge($head, array_slice($value, 2));
$cnt = ($cnt > count($out[$dex])) ? $cnt : count($out[$dex]);
}
$out = array_map(function ($e) use ($cnt){
return array_pad($e, $cnt, '-9999');
}, array_values($out));
print_r($out);
That works for PHP 5.3 and later. For older versions of PHP, you can replace the array_map
function with the following:
foreach ($out as $key => $value){
$res[] = array_pad($value, $cnt, -9999);
}
print_r($res);
NEW VERSION (for PHP 5.3 or later):
$template = array();
array_walk($arr1, function (&$e, $k) use (&$template){
$date = explode('/', $e[0]);
$dex = strtotime($date[1].'/'.$date[0].'/'.$date[2].' '.$e[1]);
$template[$dex][0] = '-9999';
});
$arr1 = array_combine(array_keys($template), $arr1);
$out = array();
$data = array($arr2, $arr3);
foreach ($data as $key => $value){
foreach ($value as $key2 => $value2){
$date = explode('/', $value2[0]);//Change date format
$dex = strtotime($date[1].'/'.$date[0].'/'.$date[2].' '.$value2[1]);
$out[$key][$dex] = array_slice($value2, 2);
}
$out[$key] += array_diff_key($template, $out[$key]);
foreach ($out[$key] as $key2 => $value2){
$arr1[$key2] = array_merge($arr1[$key2], $value2);
}
}
print_r(array_values($arr1));