按拼音首字母排序

<?php
                $temp = array();
                // 按拼音首字母排序
                foreach($res as $key=>$val){
                    $index = $this->sortByPinyin($val[‘note_name‘]);
                    $temp[$index][] = $val; //先用中间变量数组,根据字母A B C..装着集合在一起的
                }
                $list = array();
                foreach($temp as $k=>$v){
                    $list[$k][‘index‘] = $k;
                    $list[$k][‘list‘] = $v;
                }
                array_multisort($list); //用 array_multisort按键排序,也可用 ksort()
                // ksort($list);
                $list = array_values($list); //最后将键弄回数字的那些键 , A, B ,C ... => 0, 1, 2....

    /**
     * [获取字符串的拼音首字母]
     * @param  [type] $str [description]
     * @return [type]      [description]
     */
    public function sortByPinyin($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;
    }

最后的结果是:(下面是json的形式)

[
  {
    "index": "A",
    "list": [
      {
        "id": "6",
        "suid": "1",
        "note_name": "哎去"
      },
      {
        "id": "7",
        "suid": "1",
        "note_name": "abf"
      }
    ]
  },
  {
    "index": "B",
    "list": [
      {
        "id": "9",
        "suid": "1",
        "note_name": "标签2"
      }
    ]
  },
  {
    "index": "C",
    "list": [
      {
        "id": "1",
        "suid": "1",
        "note_name": "测试"
      }
    ]
  },
  {
    "index": "D",
    "list": [
      {
        "id": "3",
        "suid": "1",
        "note_name": "DSA"
      }
    ]
  }
]

原文地址:https://www.cnblogs.com/pyspang/p/10011271.html

时间: 2024-07-29 11:17:12

按拼音首字母排序的相关文章

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

城市列表-根据拼音首字母排序

今天我们就简单的实现一下城市的排序 读取我们城市的信息并通过listview展示 首先看一下我们的布局文件 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layo

sql语句按照汉字拼音首字母排序

oracle : 在oracle9i中新增了按照拼音.部首.笔画排序功能.设置NLS_SORT值SCHINESE_RADICAL_M 按照部首(第一顺序).笔划(第二顺序)排序SCHINESE_STROKE_M 按照笔划(第一顺序).部首(第二顺序)排序SCHINESE_PINYIN_M 按照拼音排序,系统的默认排序方式为拼音排序 举例如下:表名为 dept ,其中name字段是中文,下面分别实现按照单位名称的笔划.部首和拼音排序.//按照笔划排序select * from dept order

mysql 中文字段排序( 按拼音首字母排序) 的查询语句

在处理使用Mysql时,数据表采用utf8字符集,使用中发现中文不能直接按照拼音排序 如果数据表tbl的某字段name的字符编码是latin1_swedish_ci select * from `tbl` order by birary(name) asc ; 如果数据表tbl的某字段name的字符编码是utf8_general_ci SELECT name FROM `tbl` WHERE 1 ORDER BY CONVERT( name USING gbk ) COLLATE gbk_chi

mysql 中文字段排序( UTF8按拼音首字母排序)

select * from tableName CONVERT( FieldName USING gbk ) COLLATE gbk_chinese_ci desc

将包含中文的数组按拼音首字母排序

foreach ($array as $key=>$value) { $new_array[$key] = iconv('UTF-8', 'GBK', $value); } asort($new_array); foreach ($new_array as $key=>$value) { $array[$key] = iconv('GBK', 'UTF-8', $value); }

取汉字拼音首字母的方法

近期在做一个按拼音首字母排序的ListView须要取汉字拼音首字母,Deomo下载地址:http://download.csdn.net/detail/u014649598/8494777,做了例如以下的方法: 代码例如以下: package com.android.pinyin; import java.io.UnsupportedEncodingException; import android.app.Activity; import android.os.Bundle; import a

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

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

利用排序规则特点计算汉字笔划和取得拼音首字母

SQL SERVER的排序规则平时使用不是很多,也许不少初学者还比较陌生,但有一个错误大家应是经常碰到: SQL SERVER数据库,在跨库多表连接查询时,若两数据库默认字符集不同,系统就会返回这样的错误:     "无法解决 equal to 操作的排序规则冲突." 一.错误分析: 这个错误是因为排序规则不一致造成的,我们做个测试,比如:create table #t1(name varchar(20) collate Albanian_CI_AI_WS, value int) cr