这篇文章给大家分享的是有关java怎么使用正则表达式限制特殊字符的个数的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
package com.l.dubbo.service; import java.util.HashSet; import java.util.Set; import java.util.regex.Matcher; import java.util.regex.Pattern; public class ThreadPoolTest { public static boolean check1(String context, String regEx) { Pattern pattern = Pattern.compile(regEx); Matcher matcher = pattern.matcher(context); String ss = ""; String s2 = ""; boolean flag = true; int count = 0; //符合正则表达式的子段为特殊符号 //比较子段是否重复 若重复则特殊符号种类不止一种 while (matcher.find()) { if (count == 0) { ss = matcher.group(); // System.out.println(ss); } else { s2 = matcher.group(); // System.out.println(s2); } if (!(ss).equals(s2) && count > 0) { flag = false; } count++; } // System.out.println(count); return flag; } public static boolean check2(String context, String regEx) { Pattern pattern = Pattern.compile(regEx); Matcher matcher = pattern.matcher(context); boolean flag = false; //利用set的元素不能重复,来检查是否只有一种特殊符号 Set<String> set = new HashSet<String>(); while (matcher.find()) { set.add(matcher.group()); } if (set.size() == 1) { flag = true; } return flag; } public static void main(String[] args) { //s1中只包含'!‘一种特殊字符 String s1 = "dasd!a22!!!!"; //s2中包含'!‘和'@‘两种特殊字符 String s2 = "dasd!a22@!!!"; String regEx = "((?=[\\x21-\\x7e]+)[^A-Za-z0-9])"; System.out.println(check1(s1, regEx)); System.out.println(check1(s2, regEx)); System.out.println(check2(s1, regEx)); System.out.println(check2(s2, regEx)); } }
输出结果
true
false
true
false
Process finished with exit code 0
判断答案是否是ABCD的正则
public class Test { public static void main(String[] args){ Pattern pattern = Pattern.compile("^[A-D]+$"); System.out.println(pattern.matcher("A").find()); System.out.println(pattern.matcher("E").find()); } }
感谢各位的阅读!关于“java怎么使用正则表达式限制特殊字符的个数”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。