php array_orderby根据字段对二维数组进行排序

在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