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
  • asp之家 软件编程 m.aspxhome.com