import java.io.UnsupportedEncodingException;

/**
* 获取拼音码
*
* @author xmj
*
*/
public class GetPinyinCode { private final static char[] en_char_Upper = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'J', 'K', 'L', 'M', 'N', 'O',
'P', 'Q', 'R', 'S', 'T', 'W', 'X', 'Y', 'Z' };
private final static int[] posValue = { 1601, 1637, 1833, 2078, 2274, 2302, 2433, 2594, 2787, 3106, 3212, 3472,
3635, 3722, 3730, 3858, 4027, 4086, 4390, 4558, 4684, 4925, 5249, 5590 };
private final static int[] posValue2 = { 45217, 45253, 45761, 46318, 46826, 47010, 47297, 47614, 48119, 49062,
49324, 49896, 50371, 50614, 50622, 50906, 51387, 51446, 52218, 52698, 52980, 53689, 54481, 55290 }; /**
* 获取字符串的大小写拼音码,true为大写
*
* @param strChinese
* @param bUpCase
* @return
*/
public static String getPYIndexStr(String strChinese, boolean bUpCase) {
try {
StringBuffer buffer = new StringBuffer(); byte[] b = strChinese.getBytes("GBK"); int i = 0;
while (i < b.length) {
if ((b[i] & 0xFF) > 128) {
int char1 = b[(i++)] & 0xFF;
char1 <<= 8;
int chart = char1 + (b[i] & 0xFF);
buffer.append(getPYIndexChar((char) chart, bUpCase));
} else {
char c = (char) b[i];
if (!Character.isJavaIdentifierPart(c))
c = '?';
buffer.append(c);
}
i++;
}
return buffer.toString();
} catch (Exception e) {
System.out.println("取中文拼音有错" + e.getMessage());
}
return null;
} /**
* 获取字符
*
* @param strChinese
* @param bUpCase
* @return
*/
private static char getPYIndexChar(char strChinese, boolean bUpCase) {
int charGBK = strChinese;
char result = '~';
if (charGBK > 45216 && charGBK < 55290) {
for (int i = 0; i < 23; i++) {
if (charGBK >= posValue2[i] && charGBK < posValue2[i + 1]) {
result = en_char_Upper[i];
break;
}
}
}
if (!bUpCase)
result = Character.toLowerCase(result);
return result;
} /**
* 获取字符串的大小写拼音码,true为大写
*
* @param str
* @param bUpCase
* @return
*/
public static String getPYIndexStr2(String strChinese, boolean bUpCase) {
if (strChinese == null || strChinese.trim().length() == 0) {
return "";
}
String result = "";
for (int i = 0; i < strChinese.length(); i++) {
try {
result = result + getFirstLetter(strChinese.substring(i, i + 1), bUpCase);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}
return result;
} /**
* 取得给定汉字的首字母,true为大写
*
* @param chinese
* @param bUpCase
* @return
* @throws UnsupportedEncodingException
*/
private static String getFirstLetter(String strChinese, boolean bUpCase) throws UnsupportedEncodingException {
if (strChinese == null || strChinese.trim().length() == 0) {
return "";
}
strChinese = new String(strChinese.getBytes("GB2312"), "ISO8859-1");
if (strChinese.length() > 1) {
int ch_area_code = (int) strChinese.charAt(0) - 160;// 汉字区码
int ch_bit_code = (int) strChinese.charAt(1) - 160; // 汉字位码
int ch_code = ch_area_code * 100 + ch_bit_code; // 汉字区位码
if (ch_code > 1600 && ch_code < 5590) {
for (int i = 0; i < 23; i++) {
if (ch_code >= posValue[i] && ch_code < posValue[i + 1]) {
char a = en_char_Upper[i];
if (!bUpCase)
a = Character.toLowerCase(a);
strChinese = String.valueOf(a);
break;
}
}
} else {
strChinese = new String(strChinese.getBytes("ISO8859"), "GB2312");
strChinese = strChinese.substring(0, 1);
}
}
return strChinese;
} }

测试一下

Java获取汉字的大小写拼音码(汉字的拼音首字母)的更多相关文章

  1. JAVA将汉字转换为全拼以及返回中文的首字母,将字符串转移为ASCII码

    import net.sourceforge.pinyin4j.PinyinHelper;import net.sourceforge.pinyin4j.format.HanyuPinyinCaseT ...

  2. java 汉语转拼音(全拼,首字母)

    import java.util.*; import net.sourceforge.pinyin4j.PinyinHelper;import net.sourceforge.pinyin4j.for ...

  3. js汉语转拼音(全拼、首字母、拼音首字母)

    新建js文件first_alphabet.js // JavaScript Document // 汉字拼音首字母列表 本列表包含了20902个汉字,用于配合 ToChineseSpell //函数使 ...

  4. 关于java中实现在oracle数据库中实现对中文首字母进行排序的解决方案

    首先介绍Oracle 9i新增加的一个系统自带的排序函数 1.按首字母排序 在oracle9i中新增了按照拼音.部首.笔画排序功能.设置NLS_SORT值     SCHINESE_RADICAL_M ...

  5. Java序列化,解决字段为null与序列化后首字母变小写问题

    fastjson.jar package com.apt.utils; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.se ...

  6. java获取Json和http状态码

    最近再做接口自动化测试,其中有几个方法比较重要 1.获取http状态码 /* * 返回接口状态码 * */ public static String getHttpCode(String url) { ...

  7. Java获取字符串的CRC8校验码(由C程序的代码修改为了Java代码)

    CRC8算法请百度,我也不懂,这里只是把自己运行成功的结构贴出来了.方法CRC8_Tab这里没有处理,因为我的程序中没有用到. package com.crc; public class CCRC8_ ...

  8. php 中文转拼音,可以只转首字母,可以设置utf8、gbk

    <?php class Pinyin { /** * 默认是gb编码,第二个参数随意设置即为utf8编 * @param type $isInitial 是否只返回首字母 * @return t ...

  9. java获取汉字拼音首字母 --转载

    在项目中要更能根据某些查询条件(比如姓名)的首字母作为条件进行查询,比如查一个叫"李晓明"的人,可以输入'lxm'.写了一个工具类如下: import java.io.Unsupp ...

随机推荐

  1. Xray学习

    Xray 目前支持的漏洞检测类型包括: XSS漏洞检测 (key: xss) SQL 注入检测 (key: sqldet) 命令/代码注入检测 (key: cmd-injection) 目录枚举 (k ...

  2. Vue过渡和动画效果展示(案例、GIF动图演示、附源码)

    前言 本篇随笔主要写了Vue过渡和动画基础.多个元素过渡和多个组件过渡,以及列表过渡的动画效果展示.详细案例分析.GIF动图演示.附源码地址获取. 作为自己对Vue过渡和动画效果知识的总结与笔记. 因 ...

  3. UI自动化滑动登录

    一.使用OpenCV图像识别函数 1 import time 2 import cv2 3 import requests 4 from selenium import webdriver 5 fro ...

  4. python数据可视化-matplotlib入门(6)-从文件中加载数据

    前几篇都是手动录入或随机函数产生的数据.实际有许多类型的文件,以及许多方法,用它们从文件中提取数据来图形化. 比如之前python基础(12)介绍打开文件的方式,可直接读取文件中的数据,扩大了我们的数 ...

  5. plicp 点云迭代最近邻点配准法

    输入参数 点云A的极坐标集合 点云A对应Lidar所在pose 点云B的极坐标集合 点云B对应Lidar所在pose Features 根据两个点云的弧度关系确定找点的起始位置 根据两个点云的弧度关系 ...

  6. 【Hadoop】9、Sqoop组件

    目录 Sqoop组件安装与配置 1.使用xftp将软件包上传到/opt/software 2.部署sqoop(在master上执行) 3.启动sqoop集群(在master上执行) 4.连接hive配 ...

  7. 跨域原因及SpringBoot、Nginx跨域配置

    目录 概述 简单请求 跨域解决方案 概述 SpringBoot跨域配置 Nginx跨域配置 概述 MDN文档 Cross-Origin Resource Sharing (CORS) 跨域的英文是Cr ...

  8. 面试题|Docker的优缺点

    开源Linux 长按二维码加关注~ 上一篇:Linux中几个正则表达式的用法 Docker解决的问题: 由于不同的机器有不同的操作系统,以及不同的库和组件,在将一个应用部署到多台机器上需要进行大量的环 ...

  9. ansible中的playbook脚本的介绍与使用

    playbook的数据结构,遵循yaml 后缀名为yaml或者yml,这两个后缀名没有区别 字典{key:value} 列表[]或者- - alex - wusir - yantao - yuchao ...

  10. 嵌入:CAN

    说下我的学习过程.刚到公司的时候我根本不知道什么是CAN,甚至连以太网和串口通讯都不懂.领导把USBCAN分析仪拿给我,把铜线短接上,用软件在CAN1窗口点下发送,CAN2窗口马上接收到了发送出来的数 ...