-
慕仙森
尝试usort,如果你仍然在PHP 5.2或更早版本,你必须先定义一个排序函数:function sortByOrder($a, $b) {
return $a['order'] - $b['order'];}usort($myArray, 'sortByOrder');从PHP 5.3开始,您可以使用匿名函数:usort($myArray, function($a, $b) {
return $a['order'] - $b['order'];});最后使用PHP 7,您可以使用太空船运营商:usort($myArray, function($a, $b) {
return $a['order'] <=> $b['order'];});要将其扩展到多维排序,如果第一个为零,则引用第二个/第三个排序元素 - 下面将对此进行最佳说明。您还可以使用它来对子元素进行排序。usort($myArray, function($a, $b) {
$retval = $a['order'] <=> $b['order'];
if ($retval == 0) {
$retval = $a['suborder'] <=> $b['suborder'];
if ($retval == 0) {
$retval = $a['details']['subsuborder'] <=> $b['details']['subsuborder'];
}
}
return $retval;});如果需要保留关键关联,请使用uasort()- 请参阅手册中数组排序功能的比较
-
12345678_0001
function aasort (&$array, $key) { $sorter=array(); $ret=array(); reset($array); foreach ($array as $ii => $va) { $sorter[$ii]=$va[$key]; } asort($sorter); foreach ($sorter as $ii => $va) { $ret[$ii]=$array[$ii]; } $array=$ret;}aasort($your_array,"order");
-
幕布斯7119047
我用这个函数:function array_sort_by_column(&$arr, $col, $dir = SORT_ASC) {
$sort_col = array();
foreach ($arr as $key=> $row) {
$sort_col[$key] = $row[$col];
}
array_multisort($sort_col, $dir, $arr);}array_sort_by_column($array, 'order');
-
精慕HU
我通常使用usort,并传递我自己的比较函数。在这种情况下,它非常简单:function compareOrder($a, $b){
return $a['order'] - $b['order'];}usort($array, 'compareOrder');