php 数值相加,将多维数组(php)中的特定值相加

I got a multidimensional array like this:

Totalarray

(

[0] => Array

(

[city] => NewYork

[cash] => 1000

)

[1] => Array

(

[city] => Philadelphia

[cash] => 2300

)

[2] => Array

(

[city] => NewYork

[cash] => 2000

)

)

and I'd like to sum the value [cash] of the sub-arrays who got the same value[city] and obtain an array like this:

Totalarray

(

[0] => Array

(

[city] => NewYork

[cash] => 3000

)

[1] => Array

(

[city] => Philadelphia

[cash] => 2300

)

)

How can I do it?

解决方案

Try below code:

$arr = array(

array('city' => 'NewYork', 'cash' => '1000'),

array('city' => 'Philadelphia', 'cash' => '2300'),

array('city' => 'NewYork', 'cash' => '2000'),

);

$newarray = array();

foreach($arr as $ar)

{

foreach($ar as $k => $v)

{

if(array_key_exists($v, $newarray))

$newarray[$v]['cash'] = $newarray[$v]['cash'] + $ar['cash'];

else if($k == 'city')

$newarray[$v] = $ar;

}

}

print_r($newarray);

Output:

Array

(

[NewYork] => Array

(

[city] => NewYork

[cash] => 3000

)

[Philadelphia] => Array

(

[city] => Philadelphia

[cash] => 2300

)

)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值