正则表达式主要用来分析文本内容,特别适合校验数据
^符号匹配字符串的开头。
例如: ^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"
例如: ^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)国内电话:
^\d{3,4}\-?\d{6,8}$
匹配021-52540753,0798-678901,不匹配09888-0900000、098-56787
2)电子邮件
^[^@]*@[^@]*$ (不是很精确,抛砖引玉:))
3)国内邮编
^[1-9]\d{5}$
4)一个精确的数字校验
^(([1-9]([0-9]*)?(\.\d+)?)|0|(0\.\d+))$
匹配7,89,700,7.9,0.8,0 不匹配07,08000,89.,0.,00.
以上资料仅供校验参考,如想深究,可以参考相关文档
博客介绍了正则表达式的用途,它主要用于分析文本内容,尤其在数据校验方面表现出色,能有效处理文本相关任务。
1268

被折叠的 条评论
为什么被折叠?



