提取汉字首字母拼音

提取汉字首字母拼音
引自:http://dev.firnow.com/course/3_program/java/javajs/2008525/117814.html

 
public class EncodeUtil {

  
/**  国标码和区位码转换常量      */
  
public static final int GB_SP_DIFF = 160;

  
/**  存放国标一级汉字不同读音的起始区位码       */
  
public static final int[] secPosvalueList = { 160116371833207822742302243325942787310632123472,
      
363537223730385840274086439045584684492552495600 };

  
/**  存放国标一级汉字不同读音的起始区位码对应读音       */
  
public static final char[] firstLetter = { ''a''''b''''c''''d''''e''''f''''g''''h''''j''''k''''l''''m''''n''''o''''p'',
      
''q''''r''''s''''t''''w''''x''''y''''z'' };

  
/**
   * <p>获取一个字符串的拼音码   。</p>
   * 
@param oriStr
   * 
@return 一个字符串的拼音码
   
*/
  
public static String getFirstLetter(String oriStr) {
    String str 
= oriStr.toLowerCase();
    StringBuffer buffer 
= new StringBuffer();
    
char ch;
    
char[] temp;
    
for (int i = 0; i < str.length(); i++) { //依次处理str中每个字符   
      ch = str.charAt(i);
      temp 
= new char[] { ch };
      
byte[] uniCode = new String(temp).getBytes();
      
if (uniCode[0< 128 && uniCode[0> 0) { //   非汉字   
        buffer.append(temp);
      } 
else {
        buffer.append(convert(uniCode));
      }
    }
    
return buffer.toString();
  }

 
  
/**
   *  获取一个汉字的拼音首字母。   
   *   GB码两个字节分别减去160,转换成10进制码组合就可以得到区位码   
   *   例如汉字“你”的GB码是0xC4/0xE3,分别减去0xA0(160)就是0x24/0x43   
   *   0x24转成10进制就是36,0x43是67,那么它的区位码就是3667,在对照表中读音为‘n’   
   *  
@param bytes
   *  
@return char
   
*/
  
static char convert(byte[] bytes) {

    
char result = ''-'';
    
int secPosvalue = 0;
    
int i;
    
for (i = 0; i < bytes.length; i++) {
      bytes[i] 
-= GB_SP_DIFF;
    }
    secPosvalue 
= bytes[0* 100 + bytes[1];
    
for (i = 0; i < 23; i++) {
      
if (secPosvalue >= secPosvalueList[i] && secPosvalue < secPosvalueList[i + 1]) {
        result 
= firstLetter[i];
        
break;
      }
    }
    
return result;
  }
}

以上代码为提取给定汉字的首字母,比如EncodeUtil .getFirstLetter("你好"), 这样返回的结果是 ''nh'';

原文地址:https://www.cnblogs.com/sgivee/p/1762073.html