在php中,array提供了多个与排序相关的函数,例如sort, usort, asort等,但它们都是针对一维数组的,而且排序方式比较单一,甚至需要撰写额外的辅助函数来进行判断。为了方便根据二维数组的某个字段来对数组进行排序,我写了一个array_orderby函数,以实现我们想要的功能,具体代码如下:
<?php /** * 对二维数组进行按字段排序 * @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 6835