如何使用列值合并两个数组并找到另一列值的总和? [英] How to merge two arrays using column values and find sum of another column's values?
问题描述
我有两个数组,它们的键来自两个不同的查询.
I am having two arrays with same keys from two different queries.
第一个查询结果:
Array
(
[0] => Array
(
[Contribution] => 1000.00
[P_Name] => A
)
[1] => Array
(
[Contribution] => 1500.00
[P_Name] => B
)
)
第二次查询结果:
Array
(
[0] => Array
(
[Contribution] => 100.00
[P_Name] => A
)
[1] => Array
(
[Contribution] => 200.00
[P_Name] => B
)
)
第一个数组可能是空的和/或第二个可能是空的.
我想创建一个新数组,该数组找到 Contribution
值的总和,其中 P_Name
值匹配,如下所示:
I want to get the create a new array that finds the sum of Contribution
values where P_Name
values match, like this:
Array
(
[0] => Array
(
[Contribution] => 1100.00
[P_Name] => A
)
[1] => Array
(
[Contribution] => 1700.00
[P_Name] => B
)
)
我试过array_merge()
:
$result1= $this->model1->getOthersTotal($date);
$result2=$this->model1->getMiscTotal($date);
$merged_result = array_merge( $result1, $result2 );
$merged_result
包含:
Array (
[0] => Array (
[Contribution] => 1000.00
[P_Name] => A
)
[1] => Array (
[Contribution] => 1001.00
[P_Name] => A
)
[2] => Array (
[Contribution] => 69.00
[P_Name] => B
)
)
推荐答案
输入:
$a=[['Contribution'=>1000,'P_Name'=>'A'],
['Contribution'=>1500,'P_Name'=>'B'],
['Contribution'=>2000,'P_Name'=>'C']];
$b=[['Contribution'=>100,'P_Name'=>'A'],
['Contribution'=>200,'P_Name'=>'B'],
['Contribution'=>300,'P_Name'=>'D']];
如果您使用 array_column()
临时将关联键分配给子数组,那么您可以利用 array_merge_recursive()
对 P_Name
值进行分组,然后如果给定的 P_Name
有多个值,则调用 array_sum()
进行加法.
If you temporarily assign associative keys to the subarrays using array_column()
, then you can leverage array_merge_recursive()
to group on P_Name
values, then call array_sum()
to do the addition if there is more than one value to for a given P_Name
.
方法 #1:(演示)
$keyed=array_merge_recursive(array_column($a,NULL,'P_Name'),array_column($b,NULL,'P_Name'));
foreach($keyed as $p_name=>$array){
$result[]=['Contribution'=>(is_array($array['Contribution'])?array_sum($array['Contribution']):$array['Contribution']),'P_Name'=>$p_name];
}
var_export($result);
或者只是进行标准合并以创建一个数组,然后循环并随时添加.使用 array_values()
完成输出数组以重新索引元素.
Or just do a standard merge to create one array, then loop and add as you go. Finalize the output array with array_values()
to reindex the elements.
方法 #2:(演示)
foreach(array_merge($a,$b) as $array){
if(isset($result[$array['P_Name']])){
$result[$array['P_Name']]['Contribution']+=$array['Contribution'];
}else{
$result[$array['P_Name']]=$array;
}
}
$result=array_values($result);
var_export($result);
输出:(来自任一方法)
Output: (from either method)
array (
0 =>
array (
'Contribution' => 1100,
'P_Name' => 'A',
),
1 =>
array (
'Contribution' => 1700,
'P_Name' => 'B',
),
2 =>
array (
'Contribution' => 2000,
'P_Name' => 'C',
),
3 =>
array (
'Contribution' => 300,
'P_Name' => 'D',
),
)
这超出了这个问题的范围,但最好的方法可能是通过数据库查询执行此分组/添加.
It is out of the scope of this question, but chances are the best approach would be to perform this grouping/addition via database query.
这篇关于如何使用列值合并两个数组并找到另一列值的总和?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!