php数组重复求和,php-如何求和重复数据的数组值

我有一些具有相同ID值的数组,如下所示.

[

{"ID":"126871","total":"200.00","currency":"USD","name":"John"},

{"ID":"126872","total":"2000.00","currency":"Euro","name":"John"},

{"ID":"126872","total":"1000.00","currency":"Euro","name":"John"},

{"ID":"126872","total":"500.00","currency":"USD","name":"John"},

{"ID":"126872","total":"1000.00","currency":"Euro","name":"John"},

]

如果ID值重复,则将同一货币的总值相加.对于具有相同ID的不同货币,无需总计.

这就是我想要的.

[

{"ID":"126871","total":"200.00","currency":"USD","name":"John"},

{"ID":"126872","total":"4000.00","currency":"Euro","name":"John"},

{"ID":"126872","total":"500.00","currency":"USD","name":"John"}

]

我陷入上述问题.我已经尽力了.但是我得到了错误的结果.我非常感谢任何建议.

解决方法:

@Cloud我已根据您的要求提供了功能,感谢@M.我来看看这个总和部分.

$array = array(

array("ID" => "126871","total"=>"200.00","currency"=>"USD","name"=>"John"),

array("ID" => "126872","total"=>"2000.00","currency"=>"Euro","name"=>"John"),

array("ID" => "126872","total"=>"1000.00","currency"=>"Euro","name"=>"John"),

array("ID" => "126872","total"=>"500.00","currency"=>"USD","name"=>"John"),

array("ID" => "126872","total"=>"1000.00","currency"=>"Euro","name"=>"John"),

);

echo "

";

print_r($array);

function unique_multidim_array($array, $key,$key1,$addedKey) {

$temp_array = array();

$i = 0;

$key_array = array();

$key1_array = array();

foreach($array as $val) {

if (!in_array($val[$key], $key_array) && !in_array($val[$key1], $key1_array)) {

$key_array[$i] = $val[$key];

$key1_array[$i] = $val[$key1];

$temp_array[$i] = $val;

}else{

$pkey = array_search($val[$key],$key_array);

$pkey1 = array_search($val[$key1],$key1_array);

if($pkey==$pkey1){

$temp_array[$pkey][$addedKey] += $val[$addedKey];

}else{

$key_array[$i] = $val[$key];

$key1_array[$i] = $val[$key1];

$temp_array[$i] = $val;

}

// die;

}

$i++;

}

return $temp_array;

}

$nArray = unique_multidim_array($array,"ID","currency","total");

// die;

print_r($nArray);

die;

标签:php,arrays,json,sum,grouping

来源: https://codeday.me/bug/20191012/1896723.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值