[英]sort multidimensional array by values in PHP
我从类型的mysql数据库表中获取了一个数组。 我想按特定价值排序。
$arr1=array(array(12, 8, 5, 34),
array(54, 87, 32, 10),
array(23, 76, 98, 13),
array(53, 16, 24, 19));
我怎样才能按价值排序? 像第二个值的排序应该导致。
$arr1=array(array(12, 8, 5, 34),
array(53, 16, 24, 19),
array(23, 76, 98, 13),
array(54, 87, 32, 10));
我喜欢用usort
来解决这些问题。
$sortKey = 1;
usort($arr1, function($a, $b) use($sortKey){
return $a[$sortKey] - $b[$sortKey];
});
同意@RocketHazmat, array_multsort
是背后的皇家痛苦。 usort
更容易理解,但我还是认为我还要去:
$sortKey = 1;
array_multisort(array_map(function($v) use($sortKey){
return $v[$sortKey];
}, $arr1), $arr1);
它花了20分钟...... :(
这是一个演示 : http : //ideone.com/2rZYIz
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.