Java获取汉字的大小写拼音码(汉字的拼音首字母)
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获取汉字的大小写拼音码(汉字的拼音首字母)的更多相关文章
- JAVA将汉字转换为全拼以及返回中文的首字母,将字符串转移为ASCII码
import net.sourceforge.pinyin4j.PinyinHelper;import net.sourceforge.pinyin4j.format.HanyuPinyinCaseT ...
- java 汉语转拼音(全拼,首字母)
import java.util.*; import net.sourceforge.pinyin4j.PinyinHelper;import net.sourceforge.pinyin4j.for ...
- js汉语转拼音(全拼、首字母、拼音首字母)
新建js文件first_alphabet.js // JavaScript Document // 汉字拼音首字母列表 本列表包含了20902个汉字,用于配合 ToChineseSpell //函数使 ...
- 关于java中实现在oracle数据库中实现对中文首字母进行排序的解决方案
首先介绍Oracle 9i新增加的一个系统自带的排序函数 1.按首字母排序 在oracle9i中新增了按照拼音.部首.笔画排序功能.设置NLS_SORT值 SCHINESE_RADICAL_M ...
- Java序列化,解决字段为null与序列化后首字母变小写问题
fastjson.jar package com.apt.utils; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.se ...
- java获取Json和http状态码
最近再做接口自动化测试,其中有几个方法比较重要 1.获取http状态码 /* * 返回接口状态码 * */ public static String getHttpCode(String url) { ...
- Java获取字符串的CRC8校验码(由C程序的代码修改为了Java代码)
CRC8算法请百度,我也不懂,这里只是把自己运行成功的结构贴出来了.方法CRC8_Tab这里没有处理,因为我的程序中没有用到. package com.crc; public class CCRC8_ ...
- php 中文转拼音,可以只转首字母,可以设置utf8、gbk
<?php class Pinyin { /** * 默认是gb编码,第二个参数随意设置即为utf8编 * @param type $isInitial 是否只返回首字母 * @return t ...
- java获取汉字拼音首字母 --转载
在项目中要更能根据某些查询条件(比如姓名)的首字母作为条件进行查询,比如查一个叫"李晓明"的人,可以输入'lxm'.写了一个工具类如下: import java.io.Unsupp ...
随机推荐
- echarts饼图去除圈外指向横线
series: [ { name: '实时人员信息', type: 'pie', radius: ['86%', '80%'], avoidLabelOverlap: false, label: { ...
- 在Vue3项目中使用pinia代替Vuex进行数据存储
pinia是一个vue的状态存储库,你可以使用它来存储.共享一些跨组件或者页面的数据,使用起来和vuex非常类似.pina相对Vuex来说,更好的ts支持和代码自动补全功能.本篇随笔介绍pinia的基 ...
- Divide by Zero 2021 and Codeforces Round #714 (Div. 2) B. AND Sequences思维,位运算 难度1400
题目链接: Problem - B - Codeforces 题目 Example input 4 3 1 1 1 5 1 2 3 4 5 5 0 2 0 3 0 4 1 3 5 1 output 6 ...
- 3.SRE.操作手册:基础篇
SRE的根基起码应该包括:SLO.监控.告警.减少琐事和简单化. SLO(服务质量目标):用于描述服务可靠性的程度. SRE的职责并不只是将"所有工作"都自动化,并保持" ...
- ArcGIS建筑物简化和建筑物群聚合算法实验
一.下载OSM数据 首先从OpenStreetMap官网下载我们需要的实验数据,这里我选择清华和北大校园作为本次实验数据 二.数据处理 将我们下载的实验数据导入ArcGIS.由于OSM数据是.osm格 ...
- EFCore 的 DbFirst 模式
1 前言 EF6 时代,可以通过界面操作,添加数据库实体. EF Core 需要通过 CLI 来进行该操作,具体请参考EF Core官方文档:反向工程. 2 前置条件 PMC 工具(仅限 Visual ...
- python 多进程共享全局变量之Manager()
Manager支持的类型有list,dict,Namespace,Lock,RLock,Semaphore,BoundedSemaphore,Condition,Event,Queue,Value和A ...
- win10屏幕亮度无法调节,已解决
一.问题背景 最近遇到了屏幕亮度无法调节的问题,屏幕特别亮,亮瞎眼的那种,安装各种驱动和修改注册表都不起作用,右键显示器设置根本找不到亮度调节,有时候可以找到但是调节不起作用. 二.发现原因 经过各种 ...
- vue下一代状态管理Pinia.js 保证你看的明明白白!
1.pinia的简单介绍 Pinia最初是在2019年11月左右重新设计使用Composition API的 Vue 商店外观的实验. 从那时起,最初的原则相同,但 Pinia 适用于 Vue 2 和 ...
- B08. BootstrapBlazor实战 Menu 导航菜单使用(2)
接上篇: B08. BootstrapBlazor实战 Menu 导航菜单使用(1) 3.项目模板 节省时间,直接使用 Bootstrap Blazor App 模板快速搭建项目 传送门: https ...