欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

二维数组中如何按指定条件合并成一个数组

程序员文章站 2022-05-30 09:35:22
...
合并数据为一个数组,如果属性相等的则增加数量,商品ID,属性不同的商品则不合并。

如下有两数组,求解该如何按条件合并为一个数组。

$item_1 = array(
[0]=> array(
                'goods_id'=>1,
                'price'=>1,
                'goods_name'=>'商品1',
                'goods_attr_id'=>'1',
                'num'=>1,
        ),
        [1]=> array(
        
                'goods_id'=>2,
                'price'=>10,
                'goods_name'=>'测试商品2',
                'goods_attr_id'=>'3',
                'num'=>2,
        
        ),
        [2]=> array(
        
                'goods_id'=>3,
                'price'=>20,
                'goods_name'=>'测试商品3',
                'goods_attr_id'=>'4',
                'num'=>3,
        
        ),

);

$item_2 = array(

        [0]=> array(
        
                'goods_id'=>1,
                'price'=>1,
                'goods_name'=>'商品1',
                'goods_attr_id'=>'1,2',
                'num'=>1,
        
        ),
        [1]=> array(
        
                'goods_id'=>2,
                'price'=>10,
                'goods_name'=>'测试商品2',
                'goods_attr_id'=>'3',
                'num'=>2,
        
        ),
        [2]=> array(
        
                'goods_id'=>4,
                'price'=>30,
                'goods_name'=>'测试商品4',
                'goods_attr_id'=>'5',
                'num'=>1,
        ),
);

回复内容:

合并数据为一个数组,如果属性相等的则增加数量,商品ID,属性不同的商品则不合并。

如下有两数组,求解该如何按条件合并为一个数组。

$item_1 = array(
[0]=> array(
                'goods_id'=>1,
                'price'=>1,
                'goods_name'=>'商品1',
                'goods_attr_id'=>'1',
                'num'=>1,
        ),
        [1]=> array(
        
                'goods_id'=>2,
                'price'=>10,
                'goods_name'=>'测试商品2',
                'goods_attr_id'=>'3',
                'num'=>2,
        
        ),
        [2]=> array(
        
                'goods_id'=>3,
                'price'=>20,
                'goods_name'=>'测试商品3',
                'goods_attr_id'=>'4',
                'num'=>3,
        
        ),

);

$item_2 = array(

        [0]=> array(
        
                'goods_id'=>1,
                'price'=>1,
                'goods_name'=>'商品1',
                'goods_attr_id'=>'1,2',
                'num'=>1,
        
        ),
        [1]=> array(
        
                'goods_id'=>2,
                'price'=>10,
                'goods_name'=>'测试商品2',
                'goods_attr_id'=>'3',
                'num'=>2,
        
        ),
        [2]=> array(
        
                'goods_id'=>4,
                'price'=>30,
                'goods_name'=>'测试商品4',
                'goods_attr_id'=>'5',
                'num'=>1,
        ),
);

foreach ($item_1 as $key => $value) {
    $arr[$value['goods_id'].'_'.$value['goods_attr_id']]=$value;

}

foreach ($item_2 as $key => $value) {
    if(empty($arr[$value['goods_id'].'_'.$value['goods_attr_id']])){
        $arr[$value['goods_id'].'_'.$value['goods_attr_id']]=$value;

    }else{
        $arr[$value['goods_id'].'_'.$value['goods_attr_id']]['num']=$arr[$value['goods_id'].'_'.$value['goods_attr_id']]['num']+$value['num'];
    }
        
}    
var_dump($arr);

先排序,相同的排在一起,再计数。

看着挺像EC的,先按照goods_id分组,然后去重合并,具体的做法你可以搜搜php数组函数,有很多 你将这个组每个函数都玩一遍 打印看看就学会他们的用途了

相关标签: php