首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > PHP >

将二维数组从新按条件重新生成新数组

2013-01-04 
将二维数组重新按条件重新生成新数组现有数组$arrarray(0 array ( userId 1,date 2011-4

将二维数组重新按条件重新生成新数组
现有数组
$arr=array(
'0' => array ( 'userId' => 1,'date' => '2011-4-11', 'num' => '2' ),   
'1' => array ( 'userId' => 2,'date' => '2011-4-12', 'num' => '3' ),   
'2' => array ( 'userId' => 6,'date' => '2011-4-13', 'num' => '4')  
'3' => array ( 'userId' => 3,'date' => '2011-4-13', 'num' => '5')   
'4' => array ( 'userId' => 1,'date' => '2011-4-11', 'num' => '7')
'5' => array ( 'userId' => 1,'date' => '2011-4-12', 'num' => '7')      
);
如何将这个数组重新计算生成为
相同userid和data的合并求num的和
生成结果为
$arr=array(
'0' => array ( 'userId' => 1,'date' => '2011-4-11', 'num' => '9' ),   
'1' => array ( 'userId' => 2,'date' => '2011-4-12', 'num' => '3' ),   
'2' => array ( 'userId' => 6,'date' => '2011-4-13', 'num' => '4')  
'3' => array ( 'userId' => 3,'date' => '2011-4-13', 'num' => '5')   
'4' => array ( 'userId' => 1,'date' => '2011-4-12', 'num' => '7')      
);
[解决办法]
$arr=array(
'0' => array ( 'userId' => 1,'date' => '2011-4-11', 'num' => '2' ),   
'1' => array ( 'userId' => 2,'date' => '2011-4-12', 'num' => '3' ),   
'2' => array ( 'userId' => 6,'date' => '2011-4-13', 'num' => '4'),   
'3' => array ( 'userId' => 3,'date' => '2011-4-13', 'num' => '5'),   
'4' => array ( 'userId' => 1,'date' => '2011-4-11', 'num' => '7'),
'5' => array ( 'userId' => 1,'date' => '2011-4-12', 'num' => '7'),   
);
foreach($arr as $v) {
  if(! $r[$v['userId'].'_'.$v['date']])
    $r[$v['userId'].'_'.$v['date']] = $v;
  else
    $r[$v['userId'].'_'.$v['date']]['num'] += $v['num'];
}
print_r(array_values($r));

Array
(
    [0] => Array
        (
            [userId] => 1
            [date] => 2011-4-11
            [num] => 9
        )

    [1] => Array
        (
            [userId] => 2
            [date] => 2011-4-12


            [num] => 3
        )

    [2] => Array
        (
            [userId] => 6
            [date] => 2011-4-13
            [num] => 4
        )

    [3] => Array
        (
            [userId] => 3
            [date] => 2011-4-13
            [num] => 5
        )

    [4] => Array
        (
            [userId] => 1
            [date] => 2011-4-12
            [num] => 7
        )

)

热点排行