我有一系列没有任何分类的城镇。我想按[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
任何帮助都将不胜感激。
答案 0 :(得分:1)
看看uasort()函数:
答案 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上进行排序。 每个省都在我的页面上的列表中手动引用,这也让我可以控制放置。
但是,这个答案也可以改进......但上面的工作没有太多的努力。