SortService.php 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: Administrator
  5. * Date: 21/11/23
  6. * Time: 19:05
  7. */
  8. namespace App\Services\Api;
  9. class SortService
  10. {
  11. // $list 二维数组
  12. public static function getResultList($list)
  13. {
  14. return self::groupByFirstLetter($list);
  15. }
  16. protected static function groupByFirstLetter($list)
  17. {
  18. $r_list = [];
  19. foreach ($list as $key => $val) {
  20. $letter = self::firstChar($val['name']);
  21. $val['letter'] = $letter;
  22. $r_list[$letter][] = $val;
  23. }
  24. foreach ($r_list as $k => $v) {
  25. $r_list[$k] = self::listSortBy($v, 'name');
  26. }
  27. ksort($r_list);
  28. $r_list = array_values($r_list);
  29. return $r_list;
  30. }
  31. protected static function listSortBy($list, $field)
  32. {
  33. $arr = $result = [];
  34. foreach ($list as $key => $val) {
  35. $arr[$key] = &$val[$field];
  36. }
  37. asort($arr);
  38. foreach ($arr as $k => $v) {
  39. $result[] = &$list[$k];
  40. }
  41. return $result;
  42. }
  43. public static function firstChar($s)
  44. {
  45. $s0 = mb_substr($s, 0, 3); //获取名字的姓
  46. $s = iconv('UTF-8', 'gb2312', $s0); //将UTF-8转换成GB2312编码
  47. if (ord($s0) > 128) { //汉字开头,汉字没有以U、V开头的
  48. $asc = ord($s[0]) * 256 + ord($s[0]) - 65536;
  49. if ($asc >= -20319 and $asc <= -20284) return "A";
  50. if ($asc >= -20283 and $asc <= -19776) return "B";
  51. if ($asc >= -19775 and $asc <= -19219) return "C";
  52. if ($asc >= -19218 and $asc <= -18711) return "D";
  53. if ($asc >= -18710 and $asc <= -18527) return "E";
  54. if ($asc >= -18526 and $asc <= -18240) return "F";
  55. if ($asc >= -18239 and $asc <= -17760) return "G";
  56. if ($asc >= -17759 and $asc <= -17248) return "H";
  57. if ($asc >= -17247 and $asc <= -17418) return "I";
  58. if ($asc >= -17417 and $asc <= -16475) return "J";
  59. if ($asc >= -16474 and $asc <= -16213) return "K";
  60. if ($asc >= -16212 and $asc <= -15641) return "L";
  61. if ($asc >= -15640 and $asc <= -15166) return "M";
  62. if ($asc >= -15165 and $asc <= -14923) return "N";
  63. if ($asc >= -14922 and $asc <= -14915) return "O";
  64. if ($asc >= -14914 and $asc <= -14631) return "P";
  65. if ($asc >= -14630 and $asc <= -14150) return "Q";
  66. if ($asc >= -14149 and $asc <= -14091) return "R";
  67. if ($asc >= -14090 and $asc <= -13319) return "S";
  68. if ($asc >= -13318 and $asc <= -12839) return "T";
  69. if ($asc >= -12838 and $asc <= -12557) return "W";
  70. if ($asc >= -12556 and $asc <= -11848) return "X";
  71. if ($asc >= -11847 and $asc <= -11056) return "Y";
  72. if ($asc >= -11055 and $asc <= -10247) return "Z";
  73. } else if (ord($s) >= 48 and ord($s) <= 57) { //数字开头
  74. switch (iconv_substr($s, 0, 1, 'utf-8')) {
  75. case 1:
  76. return "Y";
  77. case 2:
  78. return "E";
  79. case 3:
  80. return "S";
  81. case 4:
  82. return "S";
  83. case 5:
  84. return "W";
  85. case 6:
  86. return "L";
  87. case 7:
  88. return "Q";
  89. case 8:
  90. return "B";
  91. case 9:
  92. return "J";
  93. case 0:
  94. return "L";
  95. }
  96. } else if (ord($s) >= 65 and ord($s) <= 90) { //大写英文开头
  97. return substr($s, 0, 1);
  98. } else if (ord($s) >= 97 and ord($s) <= 122) { //小写英文开头
  99. return strtoupper(substr($s, 0, 1));
  100. } else {
  101. return iconv_substr($s0, 0, 1, 'utf-8');
  102. }
  103. }
  104. }