php数组排序和分组

时间:2012-08-01 22:28:31

标签: php multidimensional-array sorting

我有一系列没有任何分类的城镇。我想按[category] ​​[3]排序,这是省,然后是[category] ​​[0],它是区域,并显示每个分组省及其区域,然后显示其下面的城镇。所以下面的数组:

Array
(
    [0] => Array
        (
            [name] => Name One
            [id] => 1
            [link] => http://mylink1.com
            [category] => Array
                (
                    [0] => Region 1
                    [1] => Town 7
                    [2] => Country
                    [3] => Province 2
                )    
        )

    [1] => Array
        (
            [name] => Name Two
            [id] => 2
            [link] => http://mylink2.com
            [category] => Array
                (
                    [0] => Region 1
                    [1] => Town
                    [2] => Country
                    [3] => Province 3
                )    
        )

    [2] => Array
        (
            [[name] => Name Three
            [id] => 3
            [link] => http://mylink3.com
            [category] => Array
                (
                    [0] => Region 1
                    [1] => Town 5
                    [2] => Country
                    [3] => Province 2
                )
        )

    [6] => Array
        (
            [name] => Name Four
            [id] => 4
            [link] => http://mylink4.com
            [category] => Array
                (
                    [0] => Region 1
                    [1] => Town 1
                    [2] => Country
                    [3] => Province 1
                )
        )

)

......应该看起来像这样:

Country (all the same)

Province 1
- Region 1
- - Town 1 name, id, link

Province 2
- Region 1
- - Town 5 name, id, link
- - Town 7 name, id, link

Province 3
- Region 1
- - Town 1 name, id, link

省是主要的分组因素,然后按地区排序,城镇没有特别的顺序,但我猜按字母顺序是有意义的。

我已经设法使用这个引用按类别对数组进行排序:Sort Multi-dimensional Array by Value但是无法理解如何进一步排序而不使用其名称在循环中专门引用省。即。

/// shortened version..
foreach($array as $key=>$value)...
   if($value == "Province 1") : do something here with these matches
     ... etc

任何帮助都将不胜感激。

3 个答案:

答案 0 :(得分:1)

答案 1 :(得分:0)

我认为你不能一步到位。

您可以按以下方式对值进行分组:

$grouped = array();

foreach ($data as $group)
{
    $grouped[ $group['category'][3] ][ $group['category'][0] ][ $group['category'][1] ] = array(/* ... */);
}

但你仍然需要使用ksort()对每个数组(及其子数组)进行排序。

您应该检查是否可以获得已预先排序的值。例如,如果您正在使用数据库来检索此值,那么在数据库中对它们进行排序并将它们放入PHP代码中的正确(分组)结构中将是非常简单的。

答案 2 :(得分:0)

循环遍历数组我已经为我正在寻找的类别使用了一个开关,然后为每个组构建了另一个数组。从那里我可以按地区排序:

foreach($arr as $town){                             
    switch($town['blogcats']){                                  
        case "Province 1" : $province1[] = $town;
        break;
        case...
        etc
    }
}

然后可以输出每个新的分组数组:

foreach($province1 as $eachtown) {
    echo $newtown['name'];
    ... and so forth.
}

在第二个循环中,可以在Region上进行排序。 每个省都在我的页面上的列表中手动引用,这也让我可以控制放置。

但是,这个答案也可以改进......但上面的工作没有太多的努力。