1、^和$分别表示一个字符串的开始和结束
eg:
“^one”:表示所有以”one”开始的字符串("one cat","one123",·····)
"a dog$":表示所以以"a dog"结尾的字符串("it is a dog",·····)
"^apple$":表示开始和结尾都是"apple"的字符串
"banana":表示任何包含"banana"的字符串。
2 '*','+'和'?'这三个符号,表示一个或N个字符重复出现的次数。它们分别表示“没有或更多”,“一次或更多”,“没有或一次”
eg:
"ab*" 这里表示b的个数可以无限多,也可以没有"a","abbbbbbbb"
"ab+" 表示b至少有一个, "ab" "abbbbbb"
"ab?" 只能表示"a"或者"ab"
3、大括号括起来({}),表示一个重复的具体范围
eg:
"ab{4}" 则表示"abbbb"
"ab{1,}" 说明至少有一个b,也可以有多个
"ab{3,4}" a后面跟着3个或者4个b
4、| 或操作,一般对象需要小括号包含
eg:
"(a|b)" 表示"a" 或 "b"
5、[] 表示区间 一般与“-”搭配使用 表示有在这个区间有一个字符 若没有"-"则表示取[]里面的一个字符
eg:
[abcd] 表示abcd里面的一个字符
"[a-z]" 表示在a-z这个区间有一个字符
"[a-zA-Z]$" 表示以一个字母结尾
"[0-9]$" 表示以一个数字结尾
tips: [0-9] 等价于 \d 表示一个数字
[^0-9] 等价于\D 表示一个非数字的字符
[A-Za-z0-9_] 等价于“\w” 匹配包括下划线的任何单词字符
[^A-Za-z0-9_] 等价于 “\W” 匹配任何非单词字符
6、"."匹配除"\r\n"之外的任何单个字符
eg:
"^.{5}$" 表示任意的5位字符
"a.[a-z]" 表示一个三位的字符
移动:134(0-8)、135、136、137、138、139、147、150、151、152、157、158、159、178、182、183、184、187、188
联通:130、131、132、145、155、156、171、175、176、185、186
电信:133、153、173、177、180、181、189
全球星:1349
虚拟运营商:170
手机号正则:"^((13[0-9])|(14[5,7])|(15[0-3,5-9])|(17[0,1,3,5-8])|(18[0-9])|(147))\\d{8}$"
邮箱:"^\\w+([-+.]\\w+)*@\\w+([-.]\\w+)*\\.\\w+([-.]\\w+)*$";
身份证(18位):"^[1-9]\\d{5}[1-9]\\d{3}((0\\d)|(1[0-2]))(([0|1|2]\\d)|3[0-1])\\d{3}([0-9Xx])$"
判断方式:
/** 判断是否匹配正*
@paramregex正则表达式
@paraminput要匹配的字符串
@return{@code true}: 匹配{@code false}: 不匹配
*/
public static boolean isMatch(String regex,CharSequence input) {
returninput !=null&& input.length() >0&& Pattern.matches(regex,input);
}
挺好的,感谢博主的分享。