为了账号安全,请及时绑定邮箱和手机立即绑定

对多维数组(php)中的特定值求和

对多维数组(php)中的特定值求和

PHP
慕斯王 2020-02-03 12:55:00
我得到了这样的多维数组:Totalarray([0] => Array    (        [city] => NewYork        [cash] => 1000    )[1] => Array    (        [city] => Philadelphia        [cash] => 2300    )[2] => Array    (        [city] => NewYork        [cash] => 2000    ))并且我想对具有相同value [city]的子数组的值[cash]求和,并获得一个像这样的数组:Totalarray([0] => Array    (        [city] => NewYork        [cash] => 3000    )[1] => Array    (        [city] => Philadelphia        [cash] => 2300    ))我该怎么做?
查看完整描述

3 回答

?
四季花海

TA贡献1811条经验 获得超5个赞

使用功能array_reduce()组合具有相同功能的项目city:


$input = array(

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

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

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

);


$output = array_reduce(

    // Process the input list

    $input,

    // Add each $item from $input to $carry (partial results)

    function (array $carry, array $item) {

        $city = $item['city'];

        // Check if this city already exists in the partial results list

        if (array_key_exists($city, $carry)) {

            // Update the existing item

            $carry[$city]['cash'] += $item['cash'];

        } else {

            // Create a new item, index by city

            $carry[$city] = $item;

        }

        // Always return the updated partial result

        return $carry;

    },

    // Start with an empty list

    array()

);


查看完整回答
反对 回复 2020-02-03
?
慕雪6442864

TA贡献1812条经验 获得超5个赞

使用不止一个循环(或循环功能)来求和这些值是无效的。


这是一种使用临时键构建结果数组,然后在循环终止后重新索引结果数组的方法。


代码:(演示)


$array=[

    ['city' => 'NewYork', 'cash' => '1000'],

    ['city' => 'Philadelphia', 'cash' => '2300'],

    ['city' => 'NewYork', 'cash' => '2000']

];


foreach($array as $a){

    if(!isset($result[$a['city']])){

        $result[$a['city']] = $a;  // store temporary city-keyed result array (avoid Notices)

    }else{

        $result[$a['city']]['cash'] += $a['cash'];  // add current value to previous value

    }

}

var_export(array_values($result));  // remove temporary keys


查看完整回答
反对 回复 2020-02-03
  • 3 回答
  • 0 关注
  • 944 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信