php按照中文首字母排序

1> 网络上很多php的工具类可以将汉字转为拼音;

2> 将拼音进行排序即可

另一种则是类似mysql转码方式:

1     foreach ($array as $key=>$value)
2     {
3         $new_array[$key] = iconv(‘UTF-8‘, ‘GBK‘, $value);
4     }  1     foreach ($array as $key=>$value)
2     {
3         $new_array[$key] = iconv(‘UTF-8‘, ‘GBK‘, $value);
4     }
5     asort($new_array);
6     foreach ($new_array as $key=>$value)
7     {
8         $array[$key] = iconv(‘GBK‘, ‘UTF-8‘, $value);
9     }
5     asort($new_array);
6     foreach ($new_array as $key=>$value)
7     {
8         $array[$key] = iconv(‘GBK‘, ‘UTF-8‘, $value);
9     } 

综合案列

//按中文首字母排序
function orderByName($userName,$order=‘asc‘,$key=‘jlname‘){
   foreach($userName as $name){
        if(is_array($name))$char = getFirstChar($name[$key]);
        elseif(is_string($name))$char= getFirstChar($name);
        $nameArray = array();//将姓名按照姓的首字母与相对的首字母键进行配对
        if(count($charArray[$char])!=0)$nameArray = $charArray[$char];
        array_push($nameArray,$name);
        $charArray[$char] = $nameArray;
    }
    if(strtolower($order)==‘asc‘)ksort($charArray);elseif(strtolower($order)==‘desc‘)krsort($charArray);
    $newarr = array();
    $i=0;
    foreach($charArray as $ck=>$cv){
        if(is_array($cv)){
            foreach($cv as $cck=>$ccv){
                $newarr[$i++] = $ccv;
            }
        }else{
            $newarr[$i++]=$cv;
        }
    }
    /*echo ‘按首字母排序前:<br>‘;
    print_r($charArray);
    //根据键值对排序
    echo ‘按首字母排序后:<br>‘;
    print_r($charArray);*/
    return $newarr;
}
//获取中文的首字母
function getFirstChar($s){
    $s0 = mb_substr($s,0,1,‘utf-8‘);//获取名字的姓
    $s = iconv(‘UTF-8‘,‘GBK‘, $s0);//将UTF-8转换成GB2312编码
    if(ord($s0)>128){//汉字开头,汉字没有以U、V开头的
    $asc=ord($s{0})*256+ord($s{1})-65536;
        if($asc>=-20319 and $asc<=-20284)return "A";
        if($asc>=-20283 and $asc<=-19776)return "B";
        if($asc>=-19775 and $asc<=-19219)return "C";
        if($asc>=-19218 and $asc<=-18711)return "D";
        if($asc>=-18710 and $asc<=-18527)return "E";
        if($asc>=-18526 and $asc<=-18240)return "F";
        if($asc>=-18239 and $asc<=-17760)return "G";
        if($asc>=-17759 and $asc<=-17248)return "H";
        if($asc>=-17247 and $asc<=-17418)return "I";
        if($asc>=-17417 and $asc<=-16475)return "J";
        if($asc>=-16474 and $asc<=-16213)return "K";
        if($asc>=-16212 and $asc<=-15641)return "L";
        if($asc>=-15640 and $asc<=-15166)return "M";
        if($asc>=-15165 and $asc<=-14923)return "N";
        if($asc>=-14922 and $asc<=-14915)return "O";
        if($asc>=-14914 and $asc<=-14631)return "P";
        if($asc>=-14630 and $asc<=-14150)return "Q";
        if($asc>=-14149 and $asc<=-14091)return "R";
        if($asc>=-14090 and $asc<=-13319)return "S";
        if($asc>=-13318 and $asc<=-12839)return "T";
        if($asc>=-12838 and $asc<=-12557)return "W";
        if($asc>=-12556 and $asc<=-11848)return "X";
        if($asc>=-11847 and $asc<=-11056)return "Y";
        if($asc>=-11055 and $asc<=-10247)return "Z";
    }elseif(ord($s)>=48 and ord($s)<=57){//数字开头
        switch(iconv_substr($s,0,1,‘utf-8‘)){
            case 1:return "Y";
            case 2:return "E";
            case 3:return "S";
            case 4:return "S";
            case 5:return "W";
            case 6:return "L";
            case 7:return "Q";
            case 8:return "B";
            case 9:return "J";
            case 0:return "L";
        }
    }else if(ord($s)>=65 and ord($s)<=90){//大写英文开头
        return substr($s,0,1);
    }else if(ord($s)>=97 and ord($s)<=122){//小写英文开头
        return strtoupper(substr($s,0,1));
    }else{
        return iconv_substr($s0,0,1,‘utf-8‘);//中英混合的词语提取首个字符即可
    }
}

mysql实现

如果当前数据库编码是utf-8,则进行转码,转为gbk,gbk默认汉字按照拼音排序存放:

1 SELECT * FROM USER ORDER BY convert(uname using gbk) ASC

如果当前编码为gbk则:

1 SELECT * FROM USER ORDER BY uname ASC
时间: 2024-10-20 19:50:52

php按照中文首字母排序的相关文章

中文首字母 排序

因项目需要对通讯录中的联系人进行排序,需要对中文字符进行拼音转换.其实这个转换并没有想象中的那么难(因为我们只是把中文转为拼音首字母而已,比如“王”转换为字母w就可以了,而不需要转换为完整的拼音wang).对此,我们找到了一个简便的解决办法:一个老外(代码中签名的作者叫George)用c语言写了一个pinyinFirstLetter函数用于获取中文拼音首字母. 这个函数主要基于一个巨大的c语言char数组,把unicode字符集中所有中文的拼音首字母都映射进去了. pinyinFirstLett

js中文首字母排序(一)

sort()localeCompare() sort()使用,sort()函数会对使用的数组对象进行排序,排序规则安装字符编码顺序排序, 如:(无法直接比较中文) var arr = new Array(6); arr[0] = "23" arr[1] = "1" arr[2] = "8" arr[3] = "25" arr[4] = "1000" arr[5] = "1" arr.so

oc中文首字母排序

NSArray *[email protected][@"小雨",@"安安",@"小风",@"荣荣",@"张涛",@"李文荣"]; NSComparator sortblock1=^(id obj1,id obj2){ return [obj1 localizedCompare:obj2]; }; NSArray *sortarray1=[arr2 sortedArrayUsingCom

ORACLE根据中文拼音首字母排序、取得中文拼音首字母函数

根据中文拼音首字母排序.取得中文拼音首字母函数     介绍根据中文的首字母.笔画.部首排序函数[NLSSORT]:           1).首字母           SELECT * FROM T_TABLE ORDER BY NLSSORT(NAME, 'NLS_SORT=SCHINESE_PINYIN_M');           2).笔画     SELECT * FROM T_TABLE ORDER BY NLSSORT(NAME, 'NLS_SORT=SCHINESE_STRO

关于java中实现在oracle数据库中实现对中文首字母进行排序的解决方案

首先介绍Oracle 9i新增加的一个系统自带的排序函数 1.按首字母排序 在oracle9i中新增了按照拼音.部首.笔画排序功能.设置NLS_SORT值     SCHINESE_RADICAL_M   按照部首(第一顺序).笔划(第二顺序)排序     SCHINESE_STROKE_M   按照笔划(第一顺序).部首(第二顺序)排序     SCHINESE_PINYIN_M   按照拼音排序 oracle9i中新增了按照拼音.部首.笔画排序功能 用法示例: Java代码   拼音 SEL

网络获取数组信息,根据姓名按首字母排序 添加侧滑删除。

package jianlemeistaff.app.jlm.com.jianlemeistaff.activity; import android.app.Activity; import android.content.Intent; import android.graphics.Color; import android.os.Bundle; import android.support.v4.app.FragmentActivity; import android.view.Gravi

HashMap加入数据后,会自动根据首字母排序

1.Map<String, ArrayList<XX>> entityHashMap = new HashMap<>(); 然后增加一些数据,会发现根据String键值排序,并不是增加的时候的顺序, 如果是中文,会按汉字的拼音首字母排序. 2.解决方法: Map<String, ArrayList<WXsd>> entityHashMap = new LinkedHashMap<>(); 只要将HashMap==>LinkedH

Java编程实现中英混合字符串数组按首字母排序的方法

在Java中对于字符串数组的排序,我们可以使用Arrays.sort(String[])方法很便捷的进行排序.例如: ? 1 2 3 4 5 6 7 String[] arrays = new String[] { "gyu", "sdf", "zf", "大同", "收到", "地方", "三等分", "的人", "反对高铁"

Oracle 10g如何对用户姓名,按首字母排序、查询

首先介绍Oracle 9i新增加的一个系统自带的排序函数 1.按首字母排序 在oracle9i中新增了按照拼音.部首.笔画排序功能.设置NLS_SORT值     SCHINESE_RADICAL_M   按照部首(第一顺序).笔划(第二顺序)排序     SCHINESE_STROKE_M   按照笔划(第一顺序).部首(第二顺序)排序     SCHINESE_PINYIN_M   按照拼音排序 oracle9i中新增了按照拼音.部首.笔画排序功能 用法示例: 拼音 SELECT * FRO