Java 完美判断中文字符的方法
时间:2023-01-07 19:14:54
Java判断一个字符串是否有中文一般情况是利用Unicode编码(CJK统一汉字的编码区间:0x4e00–0x9fbb)的正则来做判断,但是其实这个区间来判断中文不是非常精确,因为有些中文的标点符号比如:,。等等是不能识别的。
以下是比较完善的判断方法:CharUtil.java
import java.util.regex.Pattern;
public class CharUtil {
public static void main(String[] args) {
String[] strArr = new String[] { "www.micmiu.com", "!@#$%^&*()_+{}[]|\"'?/:;<>,.", "!¥……()——:;“”‘'《》,。?、", "不要啊", "やめて", "韩佳人", "???" };
for (String str : strArr) {
System.out.println("===========> 测试字符串:" + str);
System.out.println("正则判断结果:" + isChineseByREG(str) + " -- " + isChineseByName(str));
System.out.println("Unicode判断结果 :" + isChinese(str));
System.out.println("详细判断列表:");
char[] ch = str.toCharArray();
for (int i = 0; i < ch.length; i++) {
char c = ch[i];
System.out.println(c + " --> " + (isChinese(c) ? "是" : "否"));
}
}
}
// 根据Unicode编码完美的判断中文汉字和符号
private static boolean isChinese(char c) {
Character.UnicodeBlock ub = Character.UnicodeBlock.of(c);
if (ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS
|| ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_B
|| ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION || ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS
|| ub == Character.UnicodeBlock.GENERAL_PUNCTUATION) {
return true;
}
return false;
}
// 完整的判断中文汉字和符号
public static boolean isChinese(String strName) {
char[] ch = strName.toCharArray();
for (int i = 0; i < ch.length; i++) {
char c = ch[i];
if (isChinese(c)) {
return true;
}
}
return false;
}
// 只能判断部分CJK字符(CJK统一汉字)
public static boolean isChineseByREG(String str) {
if (str == null) {
return false;
}
Pattern pattern = Pattern.compile("[\\u4E00-\\u9FBF]+");
return pattern.matcher(str.trim()).find();
}
// 只能判断部分CJK字符(CJK统一汉字)
public static boolean isChineseByName(String str) {
if (str == null) {
return false;
}
// 大小写不同:\\p 表示包含,\\P 表示不包含
// \\p{Cn} 的意思为 Unicode 中未被定义字符的编码,\\P{Cn} 就表示 Unicode中已经被定义字符的编码
String reg = "\\p{InCJK Unified Ideographs}&&\\P{Cn}";
Pattern pattern = Pattern.compile(reg);
return pattern.matcher(str.trim()).find();
}
}
标签:Java,中文字符
0
投稿
猜你喜欢
C#封装的Sqlite访问类实例
2022-04-28 15:38:13
C#实现求一组数据众数的方法
2023-06-07 00:11:53
Struts2+uploadify多文件上传实例
2023-03-19 07:53:35
解决FeignClient重试机制造成的接口幂等性
2022-01-25 11:10:35
java 中HashCode重复的可能性
2021-09-13 17:38:05
Android实现文件下载进度显示功能
2023-12-26 00:42:28
浅谈使用Java Web获取客户端真实IP的方法示例详解
2022-04-01 19:47:47
Android基于ListView实现类似Market分页加载效果示例
2021-10-01 10:44:32
C#集合遍历时删除和增加元素的方法
2021-12-11 18:53:24
RecyclerView仿应用列表实现网格布局
2021-10-24 19:35:31
C#实现钟表程序设计
2023-01-01 06:38:42
二叉搜索树实例练习
2022-09-20 22:03:06
C#中使用ADOMD.NET查询多维数据集的实现方法
2023-10-27 05:38:15
Android仿微信语音消息的录制和播放功能
2022-08-15 09:28:32
Java实现数据连接池Druid举例
2022-12-10 21:21:47
Spring IOC与DI核心重点分析
2023-11-12 14:35:55
android教程viewpager自动循环和手动循环
2021-07-23 12:03:06
springBoot 打war包 程序包com.sun.istack.internal不存在的问题及解决方案
2023-03-28 06:12:40
Java数组越界问题实例解析
2023-10-25 18:16:23
C# 创建单例的多种方式
2023-03-17 05:23:48