在php中,array提供了多个与排序相关的函数,例如sort, usort, asort等,但它们都是针对一维数组的,而且排序方式比较单一,甚至需要撰写额外的辅助函数来进行判断。为了方便根据二维数组的某个字段来对数组进行排序,我写了一个array_orderby函数,以实现我们想要的功能,具体代码如下:
/**
* 对二维数组进行按字段排序
* @param array $array 要排序的二维数组
* @param bool $orderby 根据该字段(二维数组单个元素中的键名)排序
* @param string $order 排序方式,asc:升序;desc:降序(默认)
* @param string $children 子元素字段(键名),当元素含有该字段时,进行递归排序
* @return array
*/
function array_orderby(&$array,$orderby = null,$order = 'desc',$children = false) {
if($orderby == null)
return $array;
$key_value = $new_array = array();
foreach($array as $k => $v) {
$key_value[$k] = $v[$orderby];
}
if($order == 'asc') {
asort($key_value);
}
else {
arsort($key_value);
}
reset($key_value);
foreach($key_value as $k => $v) {
$new_array[$k] = $array[$k];
// 如果有children
if($children && isset($new_array[$k][$children])) {
$new_array[$k][$children] = array_sort($new_array[$k][$children]);
}
}
$new_array = array_values($new_array); // 使键名从0开始升序排列
$array = $new_array;
return $new_array;
}
我们来看看具体的使用方法。
例子1:按年龄升序排序
$a = array(
array('name' => 'Kenvi','age' => 18),
array('name' => 'Nance','age' => 21),
.....
);
array_orderby($a,'age','asc'); // 或者$a = array_orderby($a,'age','asc');
例子2:递归到子元素
$b = array(
array(
'id' => 12,'count' => 36,
'children' => array(
array('id' => 76,'count' => 40),
array('id' => 98,'count' => 100)
)
),
array('id' => 19,'count' => 87),
......
);
array_orderby($b,'count','desc','children');
这个例子中,由于指定了'children',所以$b中id=12这个元素内的children内的各个元素也会按照同样的规则进行排序,所以里面的76和98会在结果中交换位置。
2016-02-03
3877