用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

php获取中文字符拼音首字母实例

时间:2015-01-23  来源:西部数据  作者:西部数据

在php中如果我们要获取汉字的拼音第一个字母我们先要了解asc码的范围码了,我们只要知道这个值上下限就可以使用php中的ord来获取我相关的汉字拼音了.

实例1,代码如下:

  1. function getFirstCharter($str) { 
  2.     if (emptyempty($str)) {return '';} 
  3.     $fchar = ord($str{0}); 
  4.     if ($fchar>=ord('A') && $fchar<=ord('z')) return strtoupper($str{0}); 
  5.     $s1 = iconv('UTF-8''gb2312'$str); 
  6.     $s2 = iconv('gb2312''UTF-8'$s1); 
  7.     $s = $s2 == $str ? $s1 : $str
  8.     $asc = ord($s{0})*256 + ord($s{1}) - 65536; 
  9.     if ($asc>=-20319 && $asc<=-20284) return 'A'
  10.     if ($asc>=-20283 && $asc<=-19776) return 'B'
  11.     if ($asc>=-19775 && $asc<=-19219) return 'C'
  12.     if ($asc>=-19218 && $asc<=-18711) return 'D'
  13.     if ($asc>=-18710 && $asc<=-18527) return 'E'
  14.     if ($asc>=-18526 && $asc<=-18240) return 'F'
  15.     if ($asc>=-18239 && $asc<=-17923) return 'G'
  16.     if ($asc>=-17922 && $asc<=-17418) return 'H'
  17.     if ($asc>=-17417 && $asc<=-16475) return 'J'
  18.     if ($asc>=-16474 && $asc<=-16213) return 'K'
  19.     if ($asc>=-16212 && $asc<=-15641) return 'L'
  20.     if ($asc>=-15640 && $asc<=-15166) return 'M'
  21.     if ($asc>=-15165 && $asc<=-14923) return 'N'
  22.     if ($asc>=-14922 && $asc<=-14915) return 'O'
  23.     if ($asc>=-14914 && $asc<=-14631) return 'P'
  24.     if ($asc>=-14630 && $asc<=-14150) return 'Q'
  25.     if ($asc>=-14149 && $asc<=-14091) return 'R'
  26.     if ($asc>=-14090 && $asc<=-13319) return 'S'
  27.     if ($asc>=-13318 && $asc<=-12839) return 'T'
  28.     if ($asc>=-12838 && $asc<=-12557) return 'W'
  29.     if ($asc>=-12556 && $asc<=-11848) return 'X'
  30.     if ($asc>=-11847 && $asc<=-11056) return 'Y'
  31.     if ($asc>=-11055 && $asc<=-10247) return 'Z'
  32.     return null; 
  33. }  

例如:echo getFirstCharter("程序员3aj.cn"); // 结果将输出:C

实例二,代码如下:

  1. <?php 
  2.  
  3. $limit=array//gb2312 拼音排序 
  4.     array(45217,45252), //A 
  5.     array(45253,45760), //B 
  6.     array(45761,46317), //C 
  7.     array(46318,46825), //D 
  8.     array(46826,47009), //E 
  9.     array(47010,47296), //F 
  10.     array(47297,47613), //G 
  11.     array(47614,48118), //H 
  12.     array(0,0),         //I 
  13.     array(48119,49061), //J 
  14.     array(49062,49323), //K 
  15.     array(49324,49895), //L 
  16.     array(49896,50370), //M 
  17.     array(50371,50613), //N 
  18.     array(50614,50621), //O 
  19.     array(50622,50905), //P 
  20.     array(50906,51386), //Q 
  21.     array(51387,51445), //R 
  22.     array(51446,52217), //S 
  23.     array(52218,52697), //T 
  24.     array(0,0),         //U 
  25.     array(0,0),         //V 
  26.     array(52698,52979), //W 
  27.     array(52980,53688), //X 
  28.     array(53689,54480), //Y 
  29.     array(54481,55289), //Z 
  30. ); 
  31.  
  32. $str="A:这是一个测试程序1"
  33. $str= iconv("UTF-8","gb2312"$str); 
  34. echo $str."</br>"
  35. $i=0; 
  36. while($i<strlen($str) ) { 
  37.     $tmp=bin2hex(substr($str,$i,1)); 
  38.     if($tmp>='B0'){ //汉字的开始 
  39.         $t=getLetter(hexdec(bin2hex(substr($str,$i,2)))); 
  40.         printf("%c",$t==-1 ? '*' : $t ); 
  41.         $i+=2; 
  42.     } 
  43.     else
  44.         printf("%s",substr($str,$i,1)); 
  45.         $i++; 
  46.     } 
  47.  
  48. function getLetter($num){ 
  49.     global $limit
  50.     $char_index=65; 
  51.     foreach($limit as $k=>$v){ 
  52.         if($num>=$v[0] && $num<=$v[1]){ 
  53.             $char_index+=$k
  54.             return $char_index
  55.         } 
  56.     } 
  57.     return -1; 
  58. ?>  
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门