二维数组按某一键名的值排序

$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;
}

 

posted @ 2021-08-30 11:10  知冷知热  阅读(60)  评论(0)    收藏  举报