在PHP中求和两个关联多维数组的值

时间:2014-11-21 03:10:06

标签: php arrays multidimensional-array

我试图将两个关联数组的值相加。这是第一个数组:

Array
(
[Jan 01, 2013] => Array
    (
        [COM] => 100
        [RES] => 200
    )

[Oct 28, 2014] => Array
    (
        [COM] => 300
        [RES] => 400
    )
)

这是第二个数组:

Array
(
[Jan 01, 2013] => Array
    (
        [COM] => 10
        [RES] => 20
    )

[Oct 28, 2014] => Array
    (
        [COM] => 30
        [RES] => 40
    )
)

我需要对这两个数组中的值求和,以便产生这个结果:

    Array
(
[Jan 01, 2013] => Array
    (
        [COM] => 110
        [RES] => 220
    )

[Oct 28, 2014] => Array
    (
        [COM] => 330
        [RES] => 440
    )
)

我发现这个tutorial可以对关联数组的值求和,但它似乎不适用于我的多维数组。有任何建议如何实现这一目标?谢谢。

3 个答案:

答案 0 :(得分:1)

foreach()用于第一个阵列&检查第一个数组的键是否存在于第二个数组中。如果存在计算总和。例如:

$arr1 = Array
(
    "Jan 01, 2013" => Array
    (
        "COM" => 100,
        "RES" => 200,
    ),

    "Oct 28, 2014" => Array
    (
        "COM" => 300,
        "RES" => 400,
    )
);
$arr2 = Array
(
    "Jan 01, 2013" => Array
    (
        "COM" => 10,
        "RES" => 20,
    ),

    "Oct 28, 2014" => Array
    (
        "COM" => 30,
        "RES" => 40,
   )
);

$arr3 = array();
foreach($arr1 as $key => $val):
    if(array_key_exists($key, $arr2)):
        $arr3[$key]["COM"] = $val["COM"] + $arr2[$key]["COM"];
        $arr3[$key]["RES"] = $val["RES"] + $arr2[$key]["RES"];
    endif;
endforeach;

print '<pre>';
print_r($arr3);
print '</pre>';

<强>输出:

Array
(
    [Jan 01, 2013] => Array
        (
            [COM] => 110
            [RES] => 220
        )

    [Oct 28, 2014] => Array
        (
            [COM] => 330
            [RES] => 440
        )

)

答案 1 :(得分:1)

试试这个:

<?php
   $array_01 = array(
      'a' => 1,
      'b' => 2
   );

    $array_02 = array(
      'a' => 0,
      'b' => 1,
      'c' => 2
    );

    /** first we should get the array keys union
     * this is too long...,so you can make it better :D
     * you can make this more readable
     */
    $keyUnion = array_unique(array_merge(array_keys($array_01), array_keys($array_02))); 
    $res = array();

    //sum
    foreach ($keyUnion as $k => $v) {
        $res[$v] = (isset($array_01[$v]) ? $array_01[$v] : 0) + (isset($array_02[$v]) ? $array_02[$v] : 0);
    }

    print_r($res);
?>

注意:代码只获取一维关联总和

答案 2 :(得分:1)

大多数情况下,直接/简单地迭代第二个数组的级别,并确定是将值附加到第一个数组还是将其合并求和。

代码:(Demo

$arr1 = [
    "Jan 01, 2013" => ["COM" => 100, "RES" => 200, "FOO" => 5],
    "Oct 28, 2014" => ["COM" => 300, "RES" => 400]
];
$arr2 = [
    "Jan 01, 2013" => ["COM" => 10, "RES" => 20],
    "Oct 28, 2014" => ["COM" => 30, "RES" => 40]
];

foreach ($arr2 as $date => $set) {
    foreach ($set as $key => $val) {
        if (!isset($arr1[$date][$key])) {            // val is unique to 1st array, set it
            $arr1[$date][$key] = $val;
        } else {                // val already exists in 1st array, add 2nd val to 1st val
            $arr1[$date][$key] += $val;
        }
    }
}
var_export($arr1);

由于您不知道传入数据的子数组键,并且具有关联键,因此可以使用array_merge_recursive()来合并两个数组,从而建立非常简单的求和。

基于关联值合并后,您可以循环新的多维数组。进行迭代时,将子数组和子数组的值表示为“可通过引用修改”-这意味着foreach循环将处理 actual 数组,而不是该数组的副本。有效地,这将使更改影响新数组并通过$assoc_merged交付所需的结果。

代码:(Demo

$arr1 = [
    "Jan 01, 2013" => ["COM" => 100, "RES" => 200, "FOO" => 5],
    "Oct 28, 2014" => ["COM" => 300, "RES" => 400]
];
$arr2 = [
    "Jan 01, 2013" => ["COM" => 10, "RES" => 20],
    "Oct 28, 2014" => ["COM" => 30, "RES" => 40]
];

$assoc_merged =array_merge_recursive($arr1, $arr2);
// var_export($assoc_merged);  // see what this makes

foreach ($assoc_merged as $date => &$set) {
    foreach ($set as $key => &$val) {
        $val = array_sum((array)$val);
        // (array) forces a lone value to be an array containing one element; avoids generating Warnings
    }
}
var_export($assoc_merged);

两种方法都产生相同的输出:

array (
  'Jan 01, 2013' => 
  array (
    'COM' => 110,
    'RES' => 220,
    'FOO' => 5,
  ),
  'Oct 28, 2014' => 
  array (
    'COM' => 330,
    'RES' => 440,
  ),
)
相关问题