zoukankan      html  css  js  c++  java
  • pinyin4j

    pinyin4j - 获取汉子的首字母

    package asd.we.utils;
    import net.sourceforge.pinyin4j.PinyinHelper;
    import net.sourceforge.pinyin4j.format.HanyuPinyinCaseType;
    import net.sourceforge.pinyin4j.format.HanyuPinyinOutputFormat;
    import net.sourceforge.pinyin4j.format.HanyuPinyinToneType;
    import net.sourceforge.pinyin4j.format.HanyuPinyinVCharType;
    import net.sourceforge.pinyin4j.format.exception.BadHanyuPinyinOutputFormatCombination;
     
    //工具包下载地址 http://download.csdn.net/detail/wd4871/9169865
    public class PingYinUtil {
     
        public static void main(String[] args) {
            String pinyin= getFirstSpell("阳阳");
            System.out.println(pinyin);
        }
        /**
         * 获取汉子拼音(全拼音)
         * @param inputString
         * @return
         */
        public static String getPingYin(String inputString) {
            HanyuPinyinOutputFormat format = new HanyuPinyinOutputFormat();
            format.setCaseType(HanyuPinyinCaseType.LOWERCASE);
            format.setToneType(HanyuPinyinToneType.WITHOUT_TONE);
            format.setVCharType(HanyuPinyinVCharType.WITH_V);
     
            char[] input = inputString.trim().toCharArray();
            String output = "";
     
            try {
                for (int i = 0; i < input.length; i++) {
                    if (java.lang.Character.toString(input[i]).matches("[\u4E00-\u9FA5]+")) {
                        String[] temp = PinyinHelper.toHanyuPinyinStringArray(input[i], format);
                        output += temp[0];
                    } else
                        output += java.lang.Character.toString(input[i]);
                }
            } catch (BadHanyuPinyinOutputFormatCombination e) {
                e.printStackTrace();
            }
            return output;
        }
        
        /**获取汉字串拼音首字母(第一个字母的首字母),英文字符不变  
         *   
         * **/
         public static String getFirstSpell(String chinese) {   
             try {
                StringBuffer pybf = new StringBuffer();   
                 char[] arr = chinese.toCharArray();   
                 HanyuPinyinOutputFormat defaultFormat = new HanyuPinyinOutputFormat();   
                 defaultFormat.setCaseType(HanyuPinyinCaseType.LOWERCASE);   
                 defaultFormat.setToneType(HanyuPinyinToneType.WITHOUT_TONE); 
                 if(arr.length >0){
                     String[] temp = PinyinHelper.toHanyuPinyinStringArray(arr[0], defaultFormat);   
                     if (temp != null) {   
                             pybf.append(temp[0].charAt(0));   
                     }  
                 }
                 return pybf.toString().replaceAll("\W", "").trim();
            } catch (Exception e) {
                e.printStackTrace();
            }  
            return null;
         }   
        /**  
         * 获取每个汉字音首字母,英文字符不变  
         * @param chinese 汉字串  
         * @return 汉语拼音首字母  
         */  
        public static String getEachFirstSpell(String chinese) {   
            StringBuffer pybf = new StringBuffer();   
            char[] arr = chinese.toCharArray();   
            HanyuPinyinOutputFormat defaultFormat = new HanyuPinyinOutputFormat();   
            defaultFormat.setCaseType(HanyuPinyinCaseType.LOWERCASE);   
            defaultFormat.setToneType(HanyuPinyinToneType.WITHOUT_TONE);   
            for (int i = 0; i < arr.length; i++) {   
                     //if (arr[i] > 128) {   
              //匹配是否是汉字
              if (Character.toString(arr[i]).matches("[\u4E00-\u9FA5]+")) {
    try { String[] temp = PinyinHelper.toHanyuPinyinStringArray(arr[i], defaultFormat); if (temp != null) { pybf.append(temp[0].charAt(0)); } } catch (BadHanyuPinyinOutputFormatCombination e) { e.printStackTrace(); } } else { pybf.append(arr[i]); } } return pybf.toString().replaceAll("\W", "").trim(); } /** * 获取汉字串拼音,英文字符不变 * @param chinese 汉字串 * @return 汉语拼音 */ public static String getFullSpell(String chinese) { StringBuffer pybf = new StringBuffer(); char[] arr = chinese.toCharArray(); HanyuPinyinOutputFormat defaultFormat = new HanyuPinyinOutputFormat(); defaultFormat.setCaseType(HanyuPinyinCaseType.LOWERCASE); defaultFormat.setToneType(HanyuPinyinToneType.WITHOUT_TONE); for (int i = 0; i < arr.length; i++) { //if (arr[i] > 128) {
              //匹配是否是汉字
             
    if (Character.toString(arr[i]).matches("[\u4E00-\u9FA5]+")) {
    try {   
                                    pybf.append(PinyinHelper.toHanyuPinyinStringArray(arr[i], defaultFormat)[0]);   
                            } catch (BadHanyuPinyinOutputFormatCombination e) {   
                                    e.printStackTrace();   
                            }   
                    } else {   
                            pybf.append(arr[i]);   
                    }   
            }   
            return pybf.toString();   
        }  
        
        
    }

  • 相关阅读:
    拥有自己的代码生成器—Newlife.XCode模板编写教程
    基于Newlife.XCode的权限系统(含数据集权限)【设计篇】
    拥有自己的代码生成器—NewLife.XCode代码生成器分析
    利用javascript来转换GB2312到UNICONDE &#形式
    和荣笔记 从 Unicode 到 GB2312 转换表制作程式
    如何做SVN迁移
    和荣笔记 GB2312 字符集和编码说明
    asp对象化之:基于adodb.stream的文件操作类
    Unicode 汉字内码表
    微软建议的ASP性能优化28条守则 之三
  • 原文地址:https://www.cnblogs.com/lizm166/p/13293171.html
Copyright © 2011-2022 走看看