$list = [
['name'=>'zhang','age'=>23,'sex'=>'男'],
['name'=>'李刚','age'=>31,'sex'=>'男'],
['name'=>'带善人','age'=>56,'sex'=>'男'],
['name'=>'莎宝宝','age'=>3,'sex'=>'女'],
];
$order = 'age';
$sort = 'asc';
if (!empty($orderBy) && isset($list[0][$orderBy])) {
$field = array_column($list,$orderBy);//array_column 多维数组按照纵向(列)取出
if ($sort == "desc") {
array_multisort($field,SORT_DESC,$list);//用array_multisort 结合array_column得到的结果对$arr进行排序
}else{
array_multisort($field,SORT_ASC,$list);//用array_multisort 结合array_column得到的结果对$arr进行排序
}
}
注:如果要给中文排序:先把要排序的文字按每个字分隔成数组,再把每个文字转成大写字母拼接到一起,在按照新生成的字段给数组排序
/* 部门排序 On */
foreach ($res['not_have'] as $key => $value){
if (!empty($value['department_title'])) {
$temp = str_split_unicode($value['department_title']);
foreach ($temp as $k => $v) {
if (isset($res['not_have'][$key]['department_title_inital'])) {
$res['not_have'][$key]['department_title_inital'] .= zhcnToPinyin($v);
}else{
$res['not_have'][$key]['department_title_inital'] = zhcnToPinyin($v);
}
}
}else{
$res['not_have'][$key]['department_title_inital'] = '';
}
}
$field = array_column($res['not_have'],'department_title_inital');//array_column 多维数组按照纵向(列)取出
array_multisort($field,SORT_ASC,$res['not_have']);//用array_multisort 结合array_column得到的结果对$arr进行排序
/* 部门排序 Off */
/**
* 分隔一整段文字
* @param string $str 需要处理的文字
* @param int $l 长度
* @return array
*/
function str_split_unicode($str, $l = 0) {
if ($l > 0) {
$ret = array();
$len = mb_strlen($str, "UTF-8");
for ($i = 0; $i < $len; $i += $l) {
$ret[] = mb_substr($str, $i, $l, "UTF-8");
}
return $ret;
}
return preg_split("//u", $str, -1, PREG_SPLIT_NO_EMPTY);
}
/**
* 把汉字转成拼音(一般用于排序)
* @param string $str 需要处理的字符
* @return string
*/
function zhcnToPinyin($str)//汉字转拼音函数
{
if(empty($str)){return '';}
$fchar=ord($str{0});
if($fchar>=ord('A')&&$fchar<=ord('z')) return strtoupper($str{0});
$s1=iconv('UTF-8','gb2312',$str);
$s2=iconv('gb2312','UTF-8',$s1);
$s=$s2==$str?$s1:$str;
$asc=ord($s{0})*256+ord($s{1})-65536;
if($asc>=-20319&&$asc<=-20284) return 'A';
if($asc>=-20283&&$asc<=-19776) return 'B';
if($asc>=-19775&&$asc<=-19219) return 'C';
if($asc>=-19218&&$asc<=-18711) return 'D';
if($asc>=-18710&&$asc<=-18527) return 'E';
if($asc>=-18526&&$asc<=-18240) return 'F';
if($asc>=-18239&&$asc<=-17923) return 'G';
if($asc>=-17922&&$asc<=-17418) return 'H';
if($asc>=-17417&&$asc<=-16475) return 'J';
if($asc>=-16474&&$asc<=-16213) return 'K';
if($asc>=-16212&&$asc<=-15641) return 'L';
if($asc>=-15640&&$asc<=-15166) return 'M';
if($asc>=-15165&&$asc<=-14923) return 'N';
if($asc>=-14922&&$asc<=-14915) return 'O';
if($asc>=-14914&&$asc<=-14631) return 'P';
if($asc>=-14630&&$asc<=-14150) return 'Q';
if($asc>=-14149&&$asc<=-14091) return 'R';
if($asc>=-14090&&$asc<=-13319) return 'S';
if($asc>=-13318&&$asc<=-12839) return 'T';
if($asc>=-12838&&$asc<=-12557) return 'W';
if($asc>=-12556&&$asc<=-11848) return 'X';
if($asc>=-11847&&$asc<=-11056) return 'Y';
if($asc>=-11055&&$asc<=-10247) return 'Z';
return null;
}