本文实例讲述了php自定义排序uasort函数。分享给大家供大家参考,具体如下:

项目需要风险排序,按 i(安全)<l(低风险)<m(中风险)<h(高风险) 的级别来排序

由于h排在i的前面,所以不能直接用sort来排序,要自定义。

用uasort()函数来自定义排序:

/*
 * 二维数组按指定键值排须
 */
function arr_sort($array,$key,$order="asc"){//asc是升序 desc是降序//按 i<l<m<h 排序
  $arr_nums=$arr=array();
  foreach($array as $k=>$v){
    $arr_nums[$k]=$v[$key];
  }
  if($order=='asc'){
    uasort($arr_nums,'my_sort_asc');
  }else{
    uasort($arr_nums,'my_sort_desc');
  }
  foreach($arr_nums as $k=>$v){
    $arr[$k]=$array[$k];
  }
  return $arr;
}
function my_sort_desc($a,$b){
  if($a==$b) return 0;
  if($a=='i' && $b!='i') return 1;
  if($a=='l' && $b!='i') return 1;
  if($a=='l' && $b=='i') return -1;
  if($a=='m' && $b!='h') return -1;
  if($a=='m' && $b=='h') return 1;
  if($a=='h' && $b!='h') return -1;
}
function my_sort_asc($a,$b){
  if($a==$b) return 0;
  if($a=='i' && $b!='i') return -1;
  if($a=='l' && $b!='i') return -1;
  if($a=='l' && $b=='i') return 1;
  if($a=='m' && $b!='h') return 1;
  if($a=='m' && $b=='h') return -1;
  if($a=='h' && $b!='h') return 1;
}

ps:这里再为大家推荐一款关于排序的演示工具供大家参考:

在线动画演示插入/选择/冒泡/归并/希尔/快速排序算法过程工具:

更多关于php相关内容感兴趣的读者可查看本站专题:《php数组(array)操作技巧大全》、《php排序算法总结》、《php数据结构与算法教程》、《php程序设计算法总结》、《php字符串(string)用法总结》及《php常用遍历算法与技巧总结》

希望本文所述对大家php程序设计有所帮助。