zoukankan      html  css  js  c++  java
  • 按拼音首字母排序

    <?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"
          }
        ]
      }
    ]

    最终返回类似的效果的数据:

  • 相关阅读:
    深入浅出了解OCR识别票据原理(Applying OCR Technology for Receipt Recognition)
    OCR技术浅探:基于深度学习和语言模型的印刷文字OCR系统
    Python 3.6.4 / win10 使用pip安装keras时遇到依赖的PyYAML安装出错
    简单http代理服务器搭建
    Socket之心跳包实现思路
    设计模式之访问者模式
    设计模式之责任链模式
    设计模式之策略者模式
    C#将.spl剥离成.emf文件格式
    设计模式之状态者模式
  • 原文地址:https://www.cnblogs.com/pyspang/p/10011271.html
Copyright © 2011-2022 走看看