我有一个像这样的多维数组:
array(
0 => array(
11 => 18.000,
14 => 25.100,
15 => 5.000,
16 => 8.000,
19 => 21.600'
),
1 => array(
11 => 9.100,
12 => 2.700,
14 => 2.300,
15 => 18.800,
16 => 9.500,
17 => 6.900,
19 => 9.400'
),
2 => array(
14 => 5.700
),
3 => array(
17 => 2.800,
20 => 6.000
),
4 => array(
24 => 5.000,
25 => 6.000,
26 => 2.7
),
5 => array(
16 => 2.200
),
6 => array(
14 => 13.000,
15 => 2.000,
16 => 4.300,
19 => 6.000
),
7 => array(
32 => 5.000,
36 => 18.500
)
)
二级数组的长度各不相同。但是我希望得到具有相似键的元素的值,并将它们加在一起以获得总计。
例如,如果数组被调用$multi_dime
。我希望$multi_dime[0][11]
将其添加到$multi_dime[1][11]
,依此类推。
如果以下数组中不存在该键。它应该只添加0
或忽略它。代码应继续对二级数组中的所有键执行此操作,并将结果存储在另一个数组中,如:
array( 11 => 27.1, 14 => 46.1, ...)
我怎样才能做到这一点?数组总是二维的,但可以是任意长度,第二级数组也可以是任意长度。
答案 0 :(得分:1)
只需使用foreach或for循环。这就是你使用数组的方式,无论是一维,二维,三维,四维还是二维。由于您将有多个总和,因此将sums变量设为数组。在循环之外声明它,因为在循环完成时你将需要它。
$sums = array();
foreach($multi_dime as $vals)
{
foreach($vals as $key=>$val)
{
// Now we are looping through all values in the second dimension.
// If the key is not in the sums array, make it.
if(!isset($sums[$key])) $sums[$key]=0;
// We add this sum to the key now.
$sums[$key]+= $val;
}
}
ksort($sums); // Just in case you want the keys in order.
print_r($sums); // See all the sums.
答案 1 :(得分:0)
这是一种效率较低(我假设)的方法,用于计算所有特定于键的列的总和。唯一的区别是我的方法中没有迭代条件,它确实调用了#34;更重的"功能虽然。
代码:(Demo)
$result=[];
foreach($array as $subarray){
$subarray=array_diff_key($subarray,$result); // deny iteration of previously summed subarray keys
foreach($subarray as $k=>$v){
$result[$k]=array_sum(array_column($array,$k)); // sum the whole array's column
}
}
var_export($result);
如果这是我的项目,我就会像kainaw那样编写代码(但不完全一样)。我不希望将初始值声明为0
,然后在同一次迭代中添加到0
- 这是不必要的双重处理。
代码:(Demo)
foreach($array as $subarray){
foreach($subarray as $k=>$v){
if(!isset($result[$k])){
$result[$k]=$v;
}else{
$result[$k]+=$v;
}
}
}
var_export($result);