我正试图弄清楚如何做到这一点,我有这个多维数组:
Array
(
[0] => Array
(
[time] => November 1st 10:10
[query] => movies
[set] => 1
[matches] => No matching results
[results] => 5
)
[1] => Array
(
[time] => November 1st 10:10
[query] => cinemas
[set] => 1
[matches] => No matching results
[results] => 2
)
)
在现实生活中,可能会有更多的子阵列,但是我想说我想按字母顺序对“查询”进行排序,我该如何实现呢?
我只看到整数类型或键索引的解决方案,在这种情况下,最终结果将是:
Array
(
[0] => Array
(
[time] => November 1st 10:10
[query] => cinemas
[set] => 1
[matches] => No matching results
[results] => 2
)
[1] => Array
(
[time] => November 1st 10:10
[query] => movies
[set] => 1
[matches] => No matching results
[results] => 5
)
)
非常感谢,谢谢。
答案 0 :(得分:16)
function querySort ($x, $y) {
return strcasecmp($x['query'], $y['query']);
}
usort($myArray, 'querySort');
答案 1 :(得分:2)
我经常使用此函数对多维数组进行排序:
function sortmulti ($array, $index, $order, $natsort=FALSE, $case_sensitive=FALSE) {
if(is_array($array) && count($array)>0) {
foreach(array_keys($array) as $key) {
$temp[$key]=$array[$key][$index];
}
if(!$natsort) {
if ($order=='asc') {
asort($temp);
} else {
arsort($temp);
}
}
else
{
if ($case_sensitive===true) {
natsort($temp);
} else {
natcasesort($temp);
}
if($order!='asc') {
$temp=array_reverse($temp,TRUE);
}
}
foreach(array_keys($temp) as $key) {
if (is_numeric($key)) {
$sorted[]=$array[$key];
} else {
$sorted[$key]=$array[$key];
}
}
return $sorted;
}
return $sorted;
}
运作魅力:)
答案 2 :(得分:1)
同意@Hammerite的回答, 但这是进行这种排序的最短方式。通过使用匿名函数:
,您可以从PHP 5.3开始实现相同的结果 usort($myArray, function($x, $y) {
return strcasecmp($x['query'] , $y['query']);
});
17.1。 - 只有语法修复