Java判断一个字符串中是否包含中文字符工具类
Java判断一个字符串是否有中文一般情况是利用Unicode编码(CJK统一汉字的编码区间:0x4e00–0x9fbb)的正则来做判断,但是其实这个区间来判断中文不是非常精确,因为有些中文的标点符号比如:,。等等是不能识别的。
以下是比较完善的判断方法:CharUtil.java
- package com.micmiu.utils;
- import java.util.regex.Pattern;
- /**
- * 字符通用工具类
- *
- * @author <a href="http://www.micmiu.com">Michael Sun</a>
- */
- public class CharUtil {
- /**
- * @param args
- */
- 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();
- }
- }
package com.micmiu.utils;import java.util.regex.Pattern;/*** 字符通用工具类* * @author <a href="http://www.micmiu.com">Michael Sun</a>*/
public class CharUtil {/*** @param args*/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();}
}
- ===========> 测试字符串:www.micmiu.com
- 正则判断:false -- false
- Unicode判断结果 :false
- 详细判断列表:
- w --> 否
- w --> 否
- w --> 否
- . --> 否
- m --> 否
- i --> 否
- c --> 否
- m --> 否
- i --> 否
- u --> 否
- . --> 否
- c --> 否
- o --> 否
- m --> 否
- ===========> 测试字符串:!@#$%^&*()_+{}[]|"'?/:;<>,.
- 正则判断:false -- false
- Unicode判断结果 :false
- 详细判断列表:
- ! --> 否
- @ --> 否
- # --> 否
- $ --> 否
- % --> 否
- ^ --> 否
- & --> 否
- * --> 否
- ( --> 否
- ) --> 否
- _ --> 否
- + --> 否
- { --> 否
- } --> 否
- [ --> 否
- ] --> 否
- | --> 否
- " --> 否
- ' --> 否
- ? --> 否
- / --> 否
- : --> 否
- ; --> 否
- < --> 否
- > --> 否
- , --> 否
- . --> 否
- ===========> 测试字符串:!¥……()——:;“”‘’《》,。?、
- 正则判断:false -- false
- Unicode判断结果 :true
- 详细判断列表:
- ! --> 是
- ¥ --> 是
- … --> 是
- … --> 是
- ( --> 是
- ) --> 是
- — --> 是
- — --> 是
- : --> 是
- ; --> 是
- “ --> 是
- ” --> 是
- ‘ --> 是
- ’ --> 是
- 《 --> 是
- 》 --> 是
- , --> 是
- 。 --> 是
- ? --> 是
- 、 --> 是
- ===========> 测试字符串:不要啊
- 正则判断:true -- false
- Unicode判断结果 :true
- 详细判断列表:
- 不 --> 是
- 要 --> 是
- 啊 --> 是
- ===========> 测试字符串:やめて
- 正则判断:false -- false
- Unicode判断结果 :false
- 详细判断列表:
- や --> 否
- め --> 否
- て --> 否
- ===========> 测试字符串:韩佳人
- 正则判断:true -- false
- Unicode判断结果 :true
- 详细判断列表:
- 韩 --> 是
- 佳 --> 是
- 人 --> 是
- ===========> 测试字符串:한가인
- 正则判断:false -- false
- Unicode判断结果 :false
- 详细判断列表:
- 한 --> 否
- 가 --> 否
- 인 --> 否
===========> 测试字符串:www.micmiu.com
正则判断:false -- false
Unicode判断结果 :false
详细判断列表:
w --> 否
w --> 否
w --> 否
. --> 否
m --> 否
i --> 否
c --> 否
m --> 否
i --> 否
u --> 否
. --> 否
c --> 否
o --> 否
m --> 否
===========> 测试字符串:!@#$%^&*()_+{}[]|"'?/:;<>,.
正则判断:false -- false
Unicode判断结果 :false
详细判断列表:
! --> 否
@ --> 否
# --> 否
$ --> 否
% --> 否
^ --> 否
& --> 否
* --> 否
( --> 否
) --> 否
_ --> 否
+ --> 否
{ --> 否
} --> 否
[ --> 否
] --> 否
| --> 否
" --> 否
' --> 否
? --> 否
/ --> 否
: --> 否
; --> 否
< --> 否
> --> 否
, --> 否
. --> 否
===========> 测试字符串:!¥……()——:;“”‘’《》,。?、
正则判断:false -- false
Unicode判断结果 :true
详细判断列表:
! --> 是
¥ --> 是
… --> 是
… --> 是
( --> 是
) --> 是
— --> 是
— --> 是
: --> 是
; --> 是
“ --> 是
” --> 是
‘ --> 是
’ --> 是
《 --> 是
》 --> 是
, --> 是
。 --> 是
? --> 是
、 --> 是
===========> 测试字符串:不要啊
正则判断:true -- false
Unicode判断结果 :true
详细判断列表:
不 --> 是
要 --> 是
啊 --> 是
===========> 测试字符串:やめて
正则判断:false -- false
Unicode判断结果 :false
详细判断列表:
や --> 否
め --> 否
て --> 否
===========> 测试字符串:韩佳人
正则判断:true -- false
Unicode判断结果 :true
详细判断列表:
韩 --> 是
佳 --> 是
人 --> 是
===========> 测试字符串:한가인
正则判断:false -- false
Unicode判断结果 :false
详细判断列表:
한 --> 否
가 --> 否
인 --> 否
Java判断一个字符串中是否包含中文字符工具类相关推荐
- 使用java代码判断一个字符串里是否包含中文字符
测试代码: package unicode;import org.apache.commons.lang3.StringUtils;public class ChineseTest {public s ...
- java 检测表情符号_hutool工具包:判断一个字符串中是否包含emoji表情符号(emoji-java)...
需求: 判断一个字符串中是否包含emoji表情符号. 工具: hutool工具包,emoji-java工具包 cn.hutool hutool-all 5.3.7 com.vdurmont emoji ...
- 判断一个字符串中是否包含另一个字符串
第一种办法: ES6语法 contains() 判断一个字符串中是否包含某个字符串 startsWith() 判断一个字符串中是否以某个字符串开始 endsWith() 判断一个字符串中是否以某个字符 ...
- SQL判断某列中是否包含中文字符、英文字符、纯数字,数据截取
SQL判断某列中是否包含中文字符.英文字符.纯数字 一.包含中文字符 select * from 表名 where 列名 like '%[吖-座]%' [吖-座]是中文字符集第一个到最后一个的范围,虽 ...
- Java:判断一个字符串中是否存在另一个字符子串以及判断一个字符串中是否存在指定字符
Java:判断一个字符串中包含指定字符子串,判断一个字符串中存在指定字符 字符串的contains方法可以判断一个字符串中是否存在另一个字符子串,示例如下 String Str = "Hel ...
- Java 如何判断一个字符串中是否包含某一 子字符串
对于以上问题的解决,我一般使用String.indexOf("子串")的方式解决, 请看代码: public class IndexOfTest {public static v ...
- 判断一个字符串中是否包含全部26个字母
问题:给定一个字符串儿,如何判断它里面是否包含全部26个英文字母? 就以CGTN今天的头版新闻为例,如何判断下面这段字符串儿中是否包含全部的英文字母? 字符串儿.png 其实思路很简单,动手数 ...
- 在JavaScript中如何判断一个字符串中是否包含某个字符串
事出有因 用这篇博客来说一说JavaScript检测敏感词汇和不文明用语的用法. 用法 var content = "111TMD"; if(content.indexOf(&qu ...
- python查询字符串是否包含某字符串_python 判断检测字符串中是否包含指定字符或字符串(比如:?)...
in: 10px auto; padding: 0px; color: rgb(17, 17, 17); font-family: Verdana, Arial, Helvetica, sans-se ...
最新文章
- 在vue中使用vuex,修改state的值示例
- File.documentsDirectory抛出异常Error #2014问题解决方案
- 在word中的公式以代码形式体现在web上的方法
- 使用WSUS服务器为客户端安装安全补丁
- TVS管(瞬态电压抑制二极管)好坏 简单检测方法
- 视频编解码:第一章 编解码基础
- Qt学习:QDomDocument
- 链表的应用 —— 多项式运算(加法+乘法)
- sim800c GPRS模块的透传模式
- shell逻辑判断和-a区别
- winform combobox 单机不关闭_单机脉冲除尘器铜仁单机脉冲除尘器参数
- 【优化算法】差分松鼠搜索优化算法(DSSA)【含Matlab源码 1330期】
- miscrosoft visio 2003记
- eclipse使用配置教程
- 机械设计基础课程设计【1】
- 耳机插入电脑没反应找不到realtek音频管理器
- C解析8583报文55域
- 2021秋招学习笔记
- win7系统安装VS 2019
- 2022年分体式平价蓝牙耳机,性价比高的蓝牙耳机学生党排行
热门文章
- error starting container: API error (404): network fabric_test not found“
- 黑莓 priv android 8,黑莓官方确认:黑莓Priv不会升级安卓7.0
- Verdi中文教程(VCS+加法器案例)
- html5支持drag的拖放排序插件sortable.js
- python操作excle表格(二)
- Java实现扣去图像蓝色绿色背景
- Win32API学习笔记第六章(四)
- mysql快捷键_MYSQL快捷键使用大全.DOC
- 民营企业管理现状:不改革十分危险
- Mysql Seconds_Behind_Master