字符描述:
^符号匹配字符串的开头。
例如:^abc 与"abc xyz"匹配,而不与"xyz abc"匹配。
$符号匹配字符串的结尾。
例如:abc$ 与"xyz abc"匹配,而不与"abc xyz"匹配。
注意:如果同时使用^符号和$符号,将进行精确匹配。例如:^abc$ 只与"abc"匹配。
*符号匹配0个或多个前面的字符。
例如:ab* 可以匹配"ab"、"abb"、"abbb"等。
+符号匹配至少一个前面的字符。
例如:ab+ 可以匹配"abb"、"abbb"等,但不匹配"ab"。
?符号匹配0个或1个前面的字符。
例如:ab?c? 可以且只能匹配"abc"、"abbc"、"abcc"和"abbcc"。
.符号匹配除换行符以外的任何字符。
例如:(.)+ 匹配除换行符以外的所有字符串。
x|y匹配"x"或"y"。
例如:abc|xyz 可匹配 "abc"或 "xyz",而"ab(c|x)yz"匹配 "abcyz"和"abxyz"。
{n}匹配恰好n次(n为非负整数)前面的字符。
例如:a{2} 可以匹配"aa",但不匹配"a"。
{n,}匹配至少n次(n为非负整数)前面的字符。
例如:a{3,} 匹配"aaa"、"aaaa"等,但不匹配"a"和"aa"。
注意:a{1,}等价于a+;a{0,}等价于a*。
{m,n}匹配至少m个,至多n个前面的字符。
例如:a{1,3} 只匹配"a"、"aa"和"aaa"。
注意:a{0,1}等价于a?
[xyz]表示一个字符集,匹配括号中字符的其中之一。
例如:[abc] 匹配"a"、"b"和"c"。
[^xyz]表示一个否定的字符集。匹配不在此括号中的任何字符。
例如:[^abc] 可以匹配除"a"、"b"和"c"之外的任何字符。
[a-z]表示某个范围内的字符,匹配指定区间内的任何字符。
例如:[a-z] 匹配从"a"到"z"之间的任何一个小写字母字符。
[^m-n]表示某个范围之外的字符,匹配不在指定范围内的字符。
例如:[m-n] 匹配除从"m"到"n"之间的任何字符。
/符号是转义操作符。
例如:/n 换行符
/f 分页符
/r 回车
/t 制表符
/v 垂直制表符
// 匹配"/"
// 匹配"/"
/s 任何白字符,包括空格、制表符、分页符等。等价于"[ /f/n/r/t/v]"
/S 任何非空白的字符。等价于"^/f/n/r/t/v]"
/w 任何单词字符,包括字母和下划线。等价于"[A-Za-z0-9_]"
/W 任何非单词字符。等价于"[^A-Za-z0-9_]"
/b匹配单词的结尾。
例如:ve/b 匹配单词"love"等,但不匹配"very"、"even"等。
/B匹配单词的开头。
例如:ve/B 匹配单词"very"等,但不匹配"love"等。
/d匹配一个数字字符,等价于[0-9]。
例如:abc/dxyz 匹配"abc2xyz"、"abc4xyz"等,但不匹配"abcaxyz"、"abc-xyz"等。
/D匹配一个非数字字符,等价于[^0-9]。
例如:abc/Dxyz 匹配"abcaxyz"、"abc-xyz"等,但不匹配"abc2xyz"、"abc4xyz"等。
/NUM匹配NUM个(其中NUM为一个正整数),引用回到记住的匹配。
例如:(.)/1 匹配两个连续相同的字符。
/oNUM匹配n(其中n为一个小于256的八进制换码值)。
例如:/o011 匹配制表符。
/xNUM匹配NUM(其中NUM为一个小于256的十六进制换码值)。
例如:/x41 匹配字符"A"。
以下是对正则表达式的简单应用:
1. 邮政编码
boolean checkPostcode()
{
Pattern p=Pattern.compile("[0-9]{6}");
Matcher m=p.matcher(inputStr);
if (!m.matches())
{
System.out.println("****邮政编码格式不符!*****");
return false;
}
return true;
}
java.util.regex中有两个类:Pattern和Matcher。
Pattern为模板,Matcher为被匹配者。
关于上面的程序可以参考Java的API中Pattern和Matcher类的说明。
介绍一下“[0-9]{6}”的意思:
[]中括号指定允许匹配的字符,一个[]只能允许匹配单个字符。0-9表示0到9之间的任意数字,同样A-Z就表示A到Z之间的任意字母,连接符-的意思相信你已经掌握了。{}大括号表示匹配次数,这里就表示匹配6次,即必须有6个数字。
2.EMAIL
boolean checkEmail()
{
Pattern p=Pattern.compile("[0-9A-Za-z]+@([0-9a-zA-Z]+.){1,2}(com|net|cn|com.cn)");
Matcher m=p.matcher(inputStr);
if(!m.matches())
{
System.out.println("****电子邮件格式不符!*****");
return false;
}
return true;
}
这里给出匹配的表达式:
“[0-9A-Za-z]+@([0-9a-zA-Z]+.){1,2}(com|net|cn|com.cn)”。