PHP从多维数组中比较总数


PHP compare totals from multi-dimensional array

下面的数组包含三个连续日期的值。我试图计算从第一个日期的值的总和之间的差异,从第二个日期的值的总和,从第三个日期的值的总和。

关于如何最好地完成这一点,有什么建议吗?谢谢。
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:修改后更新循环和值