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

多维数组中相同元素相加有关问题

2013-03-21 
多维数组中相同元素相加问题本帖最后由 myths621 于 2013-03-19 12:04:11 编辑首次发帖,请假高手我从redis

多维数组中相同元素相加问题
本帖最后由 myths621 于 2013-03-19 12:04:11 编辑 首次发帖,请假高手
我从redis中取出五维数组需要处理相加,如下


$a = array(

0 => array(

0=> array(

"date" => "201201",
"area"=> array(
12 => array(
click => "3",
traffic => "30"
)
)
),

1=> array(

"date" => "201202",
"area"=> array(
12 => array(
click => "8",
traffic => "40"
),
8=> array(
click => "5",
traffic => "50"
)
)
)

),

1 => array(

0=> array(

"date" => "201201",
"area"=> array(
12 => array(
click => "9",
traffic => "20"
),
8=> array(
click => "6",
traffic => "60"
)
)
),

1=> array(

"date" => "201202",
"area" => NULL
)
),


);



希望数据处理后,相同date前提下,area里相同的key所对应的click和traffic值相加,即0和1这两个大数组,date为201001的,area中12所对应的click和traffic处理后应该是12和50,8对应的是6和60,其他类推,求遍历或其他能处理成功的方法,感激不尽~! 多维数组
[解决办法]
最后结果是怎么样的? 贴一下。
[解决办法]
$t = array();
foreach ($a as $k=>$v)
{
foreach ($v as $k1=>$v1)
{
$t[0][$k1]['date'] = $v1['date'];
foreach ($v1['area'] as $k2=>$v2)
{
$t[0][$k1]['area'][$k2]['click'] += $v2['click'];
$t[0][$k1]['area'][$k2]['traffic'] += $v2['traffic'];
}
}
}
echo "<pre>";
print_r($t);
echo "<pre>";


结果如下:

Array
(
    [0] => Array
        (
            [0] => Array
                (
                    [date] => 201201
                    [area] => Array
                        (
                            [12] => Array
                                (
                                    [click] => 12


                                    [traffic] => 50
                                )

                            [8] => Array
                                (
                                    [click] => 6
                                    [traffic] => 60
                                )

                        )

                )

            [1] => Array
                (
                    [date] => 201202
                    [area] => Array
                        (
                            [12] => Array
                                (
                                    [click] => 8
                                    [traffic] => 40
                                )

                            [8] => Array
                                (
                                    [click] => 5


                                    [traffic] => 50
                                )

                        )

                )

        )

)

热点排行