php 对二个数进行求和,php-如何基于两个键求和(子总数)数组?

我有以下值的数组

Array

(

[0] => Array

(

[order_date] => 2016-01-01

[sku] => RK101

[qty] => 2

)

[1] => Array

(

[order_date] => 2016-01-01

[sku] => RK101

[qty] => 5

)

[2] => Array

(

[order_date] => 2016-01-01

[sku] => RK102

[qty] => 4

)

[3] => Array

(

[order_date] => 2016-01-02

[sku] => RK101

[qty] => 2

)

[4] => Array

(

[order_date] => 2016-01-02

[sku] => RK101

[qty] => 2

)

)

我想对数组求和,首先按日期,然后按sku,我想要如下结果

Array

(

[2016-01-01] => Array

(

[RK101] => Array

(

[qty] => 7

)

[RK102] => Array

(

[qty] => 4

)

)

[2016-01-01] => Array

(

[RK101] => Array

(

[qty] => 4

)

)

)

我已经探索了堆栈溢出问题,并发现了很多帖子,它们基于一个键来计算总和,在这种情况下,我想首先基于日期然后由sku对数组值求和.

请帮助相同

解决方法:

请尝试以下解决方案:

echo '

';

$array = Array

(

'0' => Array

(

'order_date' => '2016-01-01',

'sku' => 'RK101',

'qty' => 2

),

'1' => Array

(

'order_date' => '2016-01-01',

'sku' => 'RK101',

'qty' => 5

),

'2' => Array

(

'order_date' => '2016-01-01',

'sku' => 'RK102',

'qty' => 4

),

'3' => Array

(

'order_date' => '2016-01-02',

'sku' => 'RK101',

'qty' => 2

),

'4' => Array

(

'order_date' => '2016-01-02',

'sku' => 'RK101',

'qty' => 2

)

);

$new_array = array();

foreach ($array as $a) {

if (!isset($new_array[$a['order_date']][$a['sku']]['qty'])) {

$new_array[$a['order_date']][$a['sku']]['qty'] = 0;

}

$new_array[$a['order_date']][$a['sku']]['qty'] += $a['qty'];

}

print_r($new_array);

输出:

Array

(

[2016-01-01] => Array

(

[RK101] => Array

(

[qty] => 7

)

[RK102] => Array

(

[qty] => 4

)

)

[2016-01-02] => Array

(

[RK101] => Array

(

[qty] => 4

)

)

)

标签:arrays,php

来源: https://codeday.me/bug/20191119/2033235.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值