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
falseProcess finished with exit code 0
java判斷限定字符的正則
判斷答案是否是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()); } }
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- java 如何判斷是否是26個英文字母
- Java Pattern與Matcher字符串匹配案例詳解
- Java之Pattern.compile函數用法詳解
- Java中Pattern.compile函數的使用詳解
- Java正則表達式之Pattern類實例詳解