在java程序开发中我们会涉及到校验的问题,比如说:邮箱,电话号码,身份证号码等的校验,而在校验的时候我们会写一些语句来规定输入的内容的范围,这里就会用到正则表达式了!
1.首先我们来看看正则表达式的语法
引用于API文档中内容
字符 | |
---|---|
x | 字符 x |
\\ | 反斜线字符 |
\0n | 带有八进制值 0 的字符 n (0 <= n <= 7) |
\0nn | 带有八进制值 0 的字符 nn (0 <= n <= 7) |
\0mnn | 带有八进制值 0 的字符 mnn(0 <= m <= 3、0 <= n <= 7) |
\xhh | 带有十六进制值 0x 的字符 hh |
\uhhhh | 带有十六进制值 0x 的字符 hhhh |
\t | 制表符 ('\u0009') |
\n | 新行(换行)符 ('\u000A') |
\r | 回车符 ('\u000D') |
\f | 换页符 ('\u000C') |
\a | 报警 (bell) 符 ('\u0007') |
\e | 转义符 ('\u001B') |
\cx | 对应于 x 的控制符 |
字符类 | |
[abc] | a、b 或 c(简单类) |
[^abc] | 任何字符,除了 a、b 或 c(否定) |
[a-zA-Z] | a 到 z 或 A 到 Z,两头的字母包括在内(范围) |
[a-d[m-p]] | a 到 d 或 m 到 p:[a-dm-p](并集) |
[a-z&&[def]] | d、e 或 f(交集) |
[a-z&&[^bc]] | a 到 z,除了 b 和 c:[ad-z](减去) |
[a-z&&[^m-p]] | a 到 z,而非 m 到 p:[a-lq-z](减去) |
预定义字符类 | |
. | 任何字符(与行结束符可能匹配也可能不匹配) |
\d | 数字:[0-9] |
\D | 非数字: [^0-9] |
\s | 空白字符:[ \t\n\x0B\f\r] |
\S | 非空白字符:[^\s] |
\w | 单词字符:[a-zA-Z_0-9] |
\W | 非单词字符:[^\w] |
POSIX 字符类(仅 US-ASCII) | |
\p{Lower} | 小写字母字符:[a-z] |
\p{Upper} | 大写字母字符:[A-Z] |
\p{ASCII} | 所有 ASCII:[\x00-\x7F] |
\p{Alpha} | 字母字符:[\p{Lower}\p{Upper}] |
\p{Digit} | 十进制数字:[0-9] |
\p{Alnum} | 字母数字字符:[\p{Alpha}\p{Digit}] |
\p{Punct} |
标点符号:!"#$%&'()*+,-./:;<=>?@[\]^_`{|}
|
2.常用的正则表达式
(1)邮箱:
String s1 = "zhangsan123@qq.com";
String s2 = "qq.com";
String regex = "[a-zA-z_0-9]+@[a-zA-z]+\\.[a-zA-z_0-9]+";//定义邮箱的正则表达式
Pattern p = Pattern.compile(regex);//实例化Pattern类
Matcher m1 = p.matcher(s1);//实例化Matcher类
Matcher m2 = p.matcher(s2);//实例化Matcher类
if(m1.matches()){ //使用正则验算
System.out.println("字符串:"+s1+"是一个邮箱地址。");
}else{
System.out.println("字符串:"+s1+"不是一个邮箱地址。");
}
if(m2.matches()){ //使用正则验算
System.out.println("字符串:"+s2+"是一个邮箱地址。");
}else{
System.out.println("字符串:"+s2+"不是一个邮箱地址。");
}
上面用到的正则表达式:[a-zA-z_0-9]+@[a-zA-z]+\\.[a-zA-z_0-9]+ 。[a-zA-z_0-9]代表取值范围只能在大小写字母和数字之间,‘+’代表可以出现1次到n次,"\\."代表"."由于代表".".。
(2)电话号码:
String s1 = "13678996599";
String s2 = "1111";
String regex = "^[1]([3-8])[0-9]{9}$";//定义电话号码的正则表达式
Pattern p = Pattern.compile(regex);//实例化pattern类
Matcher m1 = p.matcher(s1);//实例化pattern类
Matcher m2 = p.matcher(s2);//实例化pattern类
if(m1.matches()){ //使用正则验算
System.out.println("字符串:"+s1+"是一个电话号码。");
}else{
System.out.println("字符串:"+s1+"不是一个电话号码。");
}
if(m2.matches()){ //使用正则验算
System.out.println("字符串:"+s2+"是一个电话号码。");
}else{
System.out.println("字符串:"+s2+"不是一个电话号码。");
}
}
这里来电话号码我用到的正则表达式是:^[1]([3-8])[0-9]{9} 在这个表达式中“^”表示表达式以1开始
(3)身份证
String s1 = "11162219600131223x";
String s2 = "511622199214022239";
String regex = "^[1-9][0-9]{5}[0-9]{4}(([1][0-2])|([0][1-9]))(([1][0-9])|([2][0-9])|([3][0-1])|([0][1-9]))([0-9]{3}([0-9]|[x]))$";//身份证的正则表达式
Pattern p = Pattern.compile(regex);
Matcher m1 = p.matcher(s1);
Matcher m2 = p.matcher(s2);
if(m1.matches()){ //使用正则验算
System.out.println("字符串:"+s1+"是一个身份证号码。");
}else{
System.out.println("字符串:"+s1+"不是一个身份证号码。");
}
if(m2.matches()){ //使用正则验算
System.out.println("字符串:"+s2+"是一个身份证号码。");
}else{
System.out.println("字符串:"+s2+"不是一个身份证号码。");
}
在这上面我都是使用的比较复杂的正则法,其中很多都可以简写的比如[0-9]可以用/d表示此类很多,就靠大家自己去查看文档了