好文档就是一把金锄头!
欢迎来到金锄头文库![会员中心]
电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本

pinyin4j的使用手册.docx

3页
  • 卖家[上传人]:公****
  • 文档编号:533504688
  • 上传时间:2023-01-03
  • 文档格式:DOCX
  • 文档大小:13.03KB
  • / 3 举报 版权申诉 马上下载
  • 文本预览
  • 下载提示
  • 常见问题
    • Pinyin4j使用手册一般用法pinyin4j的使用很方便,一般转换只需要使用PinyinHelper类的静态工具方法即可:String[] pinyin = PinyinHelper.toHanyuPinyinStringArray(‘刘’);//该类还有其他的拼音转换形式,但是基本上用不到,就不介绍了返回的数组即是该字符的拼音,如上例就是pinyin[0]=liu2,后面的数字代表声调,声调为5表示轻读,无声调之所谓返回数组,是因为被判定的汉字有可能有多个读音如果输入的参数不是汉字,则返回null拼音格式化如果对于拼音转换后的结果有一些特定的格式要求目前pinyin4j支持:l 声调格式化例如:“刘”字的格式化后为“liu2”或“liu”或“liú”l 对特殊拼音ü的的显示格式例如“u:”或“v”或“ü”l 大小写的转换例如:“liu2”或“LIU2”以上这些格式可以混合使用,下面就来介绍具体的使用方法,首先需要创建格式化对象HanyuPinyinOutputFormat,例如:HanyuPinyinOutputFormat outputFormat = new HanyuPinyinOutputFormat();然后分别调用outputFormat的set方法设置上述一些格式要求:设置声调格式:outputFormat.setToneType(HanyuPinyinToneType);方法参数HanyuPinyinToneType有以下常量对象:HanyuPinyinToneType.WITH_TONE_NUMBER 用数字表示声调,例如:liu2HanyuPinyinToneType.WITHOUT_TONE 无声调表示,例如:liuHanyuPinyinToneType.WITH_TONE_MARK 用声调符号表示,例如:liú设置特殊拼音ü的显示格式:outputFormat.setVCharType(HanyuPinyinVCharType);方法参数HanyuPinyinVCharType有以下常量对象:HanyuPinyinVCharType.WITH_U_AND_COLON 以U和一个冒号表示该拼音,例如:lu:HanyuPinyinVCharType.WITH_V 以V表示该字符,例如:lvHanyuPinyinVCharType.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.toHanyuPinyinStringArray('刘',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 貌似支持生僻字,我试过很怪异的字,都可以将其读音拼写出来,因此这个工具包还是很强的。

      点击阅读更多内容
      相关文档
      四川省眉山市2025年七年级上学期语文期中试卷及答案.pdf 山东省滨州市2025年七年级上学期语文期中试卷(A)及答案.pdf 吉林省四平市2025年七年级上学期语文期中试卷及答案.pdf 山东省临沂市2025年七年级上学期期中语文试题及答案.pdf 浙江省宁波2025年七年级上学期语文期中试卷及答案.pdf 广西贵港市2025年七年级上学期语文期中试卷及答案.pdf 广东省广州市2025年七年级上学期语文期中试卷及答案.pdf 浙江省杭州市2025年七年级上学期语文期中试卷及答案.pdf 浙江省杭州市2025年七年级上学期语文期中考试试题及答案.pdf 福建省永春二中2025-2026学年八年级上学期第一次月考历史试卷.pdf 浙江省杭州市2025年七年级上学期语文期中考试试卷及答案.pdf 山东省青岛2025年七年级上学期语文期中试卷及答案.pdf 山东省滨州市2025年七年级上学期语文期中试卷(B)及答案.pdf 吉林省松原市2025年七年级上学期语文期中试卷及答案.pdf 湖南省湘西州2025年七年级上学期语文期中试卷及答案.pdf 福建省永春华侨中学2025-2026学年八年级上学期第一次月考历史试卷.pdf 四川省广安市2025年七年级上学期语文期中试卷及答案.pdf 甘肃省平凉市2025年七年级上学期语文期中试卷及答案.pdf 上海市2025年六年级上学期语文期中考试试卷及答案.pdf 2025-2026学年八年级(上)语文10月月考模拟卷(七)含答案.pdf
      关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
      手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
      ©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.