本文实例讲述了PHP实现二维数组按照指定的字段进行排序算法。分享给大家供大家参考,具体如下:
遇到问题:把两个数组用php自带的array_merge()
函数合并之后,想按照两个数组中共有的'post_time'字段为新数组进行排序
解决办法:通过查阅官方手册,得知有array_multisort()
这个函数,可以对多个数组或多维数组进行排序,返回排序之后的数组,其中字符串键名将被保留,但是数字键名将被重新索引,从 0 开始,并以 1 递增。
下面封装了这个函数,便于调用:
/** * 二维数组按照指定字段进行排序 * @params array $array 需要排序的数组 * @params string $field 排序的字段 * @params string $sort 排序顺序标志 SORT_DESC 降序;SORT_ASC 升序 */ function arraySequence($array, $field, $sort = 'SORT_DESC') { $arrSort = array(); foreach ($array as $uniqid => $row) { foreach ($row as $key => $value) { $arrSort[$key][$uniqid] = $value; } } array_multisort($arrSort[$field], constant($sort), $array); return $array; } //测试: $arrDemo = array( array('name'=>'Jack','age'=>'22'), array('name'=>'Tom','age'=>'24'), array('name'=>'Green','age'=>'21'), array('name'=>'Ben','age'=>'23'),); $arrDemo = arraySequence($arrDemo,'age'); print_r($arrDemo);
运行结果:
Array
(
[0] => Array
(
[name] => Tom
[age] => 24
)[1] => Array
(
[name] => Ben
[age] => 23
)[2] => Array
(
[name] => Jack
[age] => 22
)[3] => Array
(
[name] => Green
[age] => 21
))
新增:按照指定的多个字段排序
/** * 二维数组按照指定的多个字段进行排序 * * 调用示例:sortArrByManyField($arr,'id',SORT_ASC,'age',SORT_DESC); */ function sortArrByManyField(){ $args = func_get_args(); if(empty($args)){ return null; } $arr = array_shift($args); if(!is_array($arr)){ throw new Exception("第一个参数应为数组"); } foreach($args as $key => $field){ if(is_string($field)){ $temp = array(); foreach($arr as $index=> $val){ $temp[$index] = $val[$field]; } $args[$key] = $temp; } } $args[] = &$arr;//引用值 call_user_func_array('array_multisort',$args); return array_pop($args); } //测试: $arrDemo = array( array('name'=>'Jack','age'=>'22'), array('name'=>'Tom','age'=>'24'), array('name'=>'Green','age'=>'21'), array('name'=>'Ben','age'=>'23'),); $arrDemo = sortArrByManyField($arrDemo,'age'); print_r($arrDemo);
运行结果:
Array
(
[0] => Array
(
[name] => Green
[age] => 21
)[1] => Array
(
[name] => Jack
[age] => 22
)[2] => Array
(
[name] => Ben
[age] => 23
)[3] => Array
(
[name] => Tom
[age] => 24
))
PHP实现二维数组按照指定的字段进行排序算法示例
- Author -
李维山声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@