本文实例讲述了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
))
PS:这里再为大家推荐一款关于排序的演示工具供大家参考:
在线动画演示插入/选择/冒泡/归并/希尔/快速排序算法过程工具:
http://tools.haodaima.com/aideddesign/paixu_ys
希望本文所述对大家PHP程序设计有所帮助。
本文PHP实现二维数组按照指定的字段进行排序算法示例到此结束。不要指望别人来帮你走路,不要指望谁能帮你挨疼。痛,要自己扛;伤,要自己愈。有些路不合脚,却必须走;有些选择不合心,却要知道适应。人只有经历过了不如意,才知道生活真的不容易。路是自己的,要走;心是自己的,要懂。所求越少,得到越多;心越简单,快乐越多。无谓于得,不计于失,才能真正体会到追求的快乐。小编再次感谢大家对我们的支持!