下面的数组包含三个连续日期的值。我试图计算从第一个日期的值的总和之间的差异,从第二个日期的值的总和,从第三个日期的值的总和。
关于如何最好地完成这一点,有什么建议吗?谢谢。Array
(
[Nov 18, 2011] => Array
(
[C] => Array
(
[C] => Array
(
[T] => 50803.805765535
)
[S] => Array
(
[T] => 32908.863528
)
)
)
[Dec 11, 2011] => Array
(
[C] => Array
(
[C] => Array
(
[T] => 31746.502038235
)
[S] => Array
(
[T] => 16836.613004414
)
)
)
[Dec 24, 2011] => Array
(
[C] => Array
(
[C] => Array
(
[T] => 43524.786543288
)
[S] => Array
(
[T] => 15722.772389011
)
)
)
)
如果你的数组命名为$arr:
$totals = array();
foreach ($arr as $key => $val){
$totals[$key] = $val['C']['C']['T'] + $val['C']['S']['T'];
}
print_r($totals);
exit;
我不确定我理解你的问题100%正确,但这里是一个尝试。如果数组为$a,则array_value_recursive()函数将只提取每个日期的'T'值,然后回显两者之间的差值。输出如下:
Nov 18, 2011 (C 50803.805766 / S 32908.863528) - Dec 11, 2011 (C 31746.502038 / S 16836.613004) = C 19057.303727 / S 16072.250524
Dec 11, 2011 (C 32908.863528 / S 31746.502038) - Dec 24, 2011 (C 16836.613004 / S 43524.786543) = C 16072.250524 / S -11778.284505
代码是:
$keys = array_keys($a);
$values = array_value_recursive('T',$a);
for($i=0;$i<count($keys);$i++) {
if (isset($keys[$i+$i])) {
printf( "%s (C %f / S %f) - %s (C %f / S %f) = C %f / S %f'n",
$keys[$i], $values[$i+$i], $values[$i+$i+1],
$keys[$i+1], $values[$i+$i+2], $values[$i+$i+3],
$values[$i+$i] - $values[$i+$i+2],
$values[$i+$i+1] - $values[$i+$i+3]
);
}
}
function array_value_recursive($key, array $arr){
$val = array();
array_walk_recursive($arr, function($v, $k) use($key, &$val){
if($k == $key) array_push($val, $v);
});
return count($val) > 1 ? $val : array_pop($val);
}
edit:修改后更新循环和值