温馨提示×

首字母排序并分组

发布时间:2020-07-07 18:33:39 来源:51CTO 阅读:358 作者:xulie911520 栏目:web开发

<?php 

/**

 * 首字母排序类

 */

class First_letter_sort {


/**

* 取汉字的第一个字的首字母

* @DateTime 2016-09-14T17:24:29+0800

* @param    string $str 

*/

public function first_charter($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 '#';  

}

/**

* 组装字母排序数组

* @DateTime 2016-09-14T17:45:10+0800

* @param   array  $array_list 

* @param   string  $field_name 

* @return                

*/

public function letter_order($array_list,$field_name){

$letterArray=array();

if(!empty($array_list)){

        foreach ($array_list as $key=>$value){

            $letter=$this->first_charter($value["$field_name"]);

            $array_list[$key]['letter']=$letter;

        }

        usort($array_list,function($a,$b){

            $al=$a['letter'];

            $bl=$b['letter'];

            if($al==$bl)return 0;

            return($al<$bl)?-1:1;

        });

        foreach ($array_list as $key => $value) {

        $letter=$value['letter'];

unset($value['letter']);

$letterArray[$letter]['letter']=$letter;

$letterArray[$letter]['letter_order'][]=$value;

        }

    }

    return array_values($letterArray);  

}

}?>


免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

免费拨打  400 100 2938 免费拨打 400 100 2938
24小时售后技术支持 24小时售后技术支持
返回顶部 返回顶部