Pinyin4j使用手册

 

一般用法

pinyin4j的使用很方便,一般转换只需要使用PinyinHelper类的静态工具方法即可:

String[] pinyin = PinyinHelper.toHanyuPinyinStringArray(‘刘’);  

//该类还有其他的拼音转换形式,但是基本上用不到,就不介绍了

返回的数组即是该字符的拼音,如上例就是pinyin[0]=liu2,后面的数字代表声调,声调为5表示轻读,无声调。之所谓返回数组,是因为被判定的汉字有可能有多个读音。如果输入的参数不是汉字,则返回null。

拼音格式化

如果对于拼音转换后的结果有一些特定的格式要求目前pinyin4j支持:

l 声调格式化。例如:“刘”字的格式化后为“liu2”或“liu”或“liú” l

l 对特殊拼音ü的的显示格式。例如“u:”或“v”或“ü”

l 大小写的转换。例如:“liu2”或“LIU2”  以上这些格式可以混合使用,下面就来介绍具体的使用方法,首先需要创建格式化对象HanyuPinyinOutputFormat,例如:  HanyuPinyinOutputFormat outputFormat = new HanyuPinyinOutputFormat();

 

然后分别调用outputFormat的set方法设置上述一些格式要求:

设置声调格式:  

outputFormat.setToneType(HanyuPinyinToneType);

 

方法参数HanyuPinyinToneType有以下常量对象:  

HanyuPinyinToneType.WITH_TONE_NUMBER 用数字表示声调,例如:liu2 HanyuPinyinToneType.WITHOUT_TONE 无声调表示,例如:liu   HanyuPinyinToneType.WITH_TONE_MARK 用声调符号表示,例如:liú

 

设置特殊拼音ü的显示格式:  

outputFormat.setVCharType(HanyuPinyinVCharType);   

方法参数HanyuPinyinVCharType有以下常量对象:

HanyuPinyinVCharType.WITH_U_AND_COLON 以U和一个冒号表示该拼音,例如:lu: HanyuPinyinVCharType.WITH_V 以V表示该字符,例如:lv HanyuPinyinVCharType.WITH_U_UNICODE 以ü表示

 

设置大小写格式  

outputFormat.setCaseType(HanyuPinyinCaseType);

HanyuPinyinCaseType.LOWERCASE 转换后以全小写方式输出 HanyuPinyinCaseType.UPPERCASE 转换后以全大写方式输出   

设置好格式对象后还是利用上述的工具类方法进行拼音转换,只不过需要将格式化对象当成方法参数传入转换方法,告知要转换的格式要求:  

String[] pinyin = PinyinHelper.toHanyuPinyinStringArray(‘刘’, outputFormat); 但该方法会有异常抛出,注意处理。

示例

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;  

public class Test {  

    public static void main(String[] args) {   

        HanyuPinyinOutputFormat outputFormat = new  HanyuPinyinOutputFormat();                                          
        outputFormat.setToneType(HanyuPinyinToneType.WITH_TONE_MARK);             
        outputFormat.setVCharType(HanyuPinyinVCharType.WITH_U_UNICODE);        
        outputFormat.setCaseType(HanyuPinyinCaseType.UPPERCASE);   

        try {       

            System.out.println(concatPinyinStringArray(PinyinHelper.toHanyuPi                 
            nyinStringArray('刘',outputFormat)));   

        } catch (BadHanyuPinyinOutputFormatCombination e) {    

            // TODO Auto-generated catch block    e.printStackTrace();    

        }   

    }      

    private static String concatPinyinStringArray(String[] pinyinArray) {          

        StringBuffer pinyinStrBuf = new StringBuffer();

        if ((null != pinyinArray) && (pinyinArray.length > 0)) {              

            for (int i = 0; i < pinyinArray.length; i++){                  

                pinyinStrBuf.append(pinyinArray[i]);                           
                pinyinStrBuf.append(System.getProperty("line.separator"));

            }

        }          

        String outputString = pinyinStrBuf.toString();

        return outputString;     

    }

}

输出结果为:LIÚ

其他

l PinyinHelper还有其他的静态方法,但示例和讲解中使用的方法是常见的拼音格式,因 此其他静态方法我没有调研其含义。  l

l 貌似支持生僻字,我试过很怪异的字,都可以将其读音拼写出来,因此这个工具包还是 很强的。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值