将具有公共值的数组组合到新数组中

时间:2016-04-19 07:03:22

标签: php arrays grouping

我正在研究一个项目,我坚持这个我的问题是我有一个数组,如下所示

$arr1  =   array(
        array
        (
            'id' => '1',
            'city' => 'A.bad',
        ),
        array
        (
            'id' => '2',
            'city' => 'Pune',
        ),
        array
        (
            'id' => '1',
            'city' => 'Mumbai',
        )
        );

我必须通过id比较这个,我想要输出如下。

$result = array(
       array(
          'id'='1',
          'city'='A.bad','Mumbai'
      ),
      array(
          'id'='2',
          'city'='Pune'
      )
);

如果我们的ID与第一个相同,则为A.bad,因此它会占用它,而在第三个中它的id为1,城市为mumbai所以它将组合为id 1和city作为a.badmumbai和其他记录以相同方式过滤。

1 个答案:

答案 0 :(得分:5)

循环遍历数组并根据array生成新的id。您可以试试这个 -

$new = array();
foreach($arr1 as $array) {
    $new[$array['id']]['id']= $array['id'];
    // check if the city value set for that id
    // if set the concatenate else set with the city name 
    $new[$array['id']]['city']= (isset( $new[$array['id']]['city'])) ?  ($new[$array['id']]['city'] . ',' . $array['city']) : $array['city'];
}

Fiddle

如果您从数据库获取数据,您也可以在查询中对它们进行分组。