合併資料為一個數組,如果屬性相等的則增加數量,商品ID,屬性不同的商品則不合併。
如下有兩數組,求解如何依條件合併為一個數組。
<code>$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, ), );</code>
合併資料為一個數組,如果屬性相等的則增加數量,商品ID,屬性不同的商品則不合併。
如下有兩數組,求解如何依條件合併為一個數組。
<code>$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, ), );</code>
<code>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); </code>
先排序,相同的排在一起,再計數。
看著挺像EC的,先按照goods_id分組,然後去重合併,具體的做法你可以搜搜php數組函數,有很多你將這個組每個函數都玩一遍打印看看就學會他們的用途了