元字符^(和数字6在同一个键位上的符号)和$都 匹配一个位置,这和b有点类似。^匹配你 要用来查找的字符串的开头,$匹配结尾。这两个代码在验证输入的内容时非常有用,比如一个网站如果 要求你填写的QQ号必须为5位到12位数字时,可以使用:^d{5,12}$。
这里的{5,12}和前面介绍过的{2}是 类似的,只不过{2}匹配只能不多不少重复2次,{5,12}则是重复的次数不能少于5次,不能多于12次, 否则都不匹配。
因为使用了^和$,所以输入的整个字 符串都要用来和d{5,12}来匹配,也就是说整个输入必 须是5到12个数字,因此如果输入的QQ号能匹配这个正则表达式的话,那就符合要求了。
和忽略大小写的选项类似,有些正则表达式处理工具还有一个处理多行的选项。如果选中了这个选项,^和$的意义就变成了匹配行的开始处和结束处。
字符转义
如果你想查找元字符本身的话,比如你查找.,或者*, 就出现了问题:你没办法指定它们,因为它们会被解释成别的意思。这时你就得使用来取消这些字符的 特殊意义。因此,你应该使用.和*。 当然,要查找本身,你也得用.
例如:unibetter.com匹配unibetter.com,C:Windows匹配C:Windows。
重复
你已经看过了前面的*,+,{2},{5,12}这几个匹配重复的方式了。下面是 正则表达式中所有的限定符(指定数量的代码,例如*,{5,12}等):
代码/语法 | 说明 |
---|---|
* | 重复零次或更多次 |
+ | 重复一次或更多次 |
? | 重复零次或一次 |
{n} | 重复n次 |
{n,} | 重复n次或更多次 |
{n,m} | 重复n到m次 |
下面是一些使用重复的例子:
Windowsd+匹配Windows后面跟1 个或更多数字
^w+匹配一行的第一个单词(或整个字符串的第 一个单词,具体匹配哪个意思得看选项设置)
字符类
要想查找数字,字母或数字,空白是很简单的,因为已经有了对应这些字符集合的元字符,但是如果你想匹配没有预定义元字符的字符集合(比如元音字母 a,e,i,o,u),应该怎么办?
很简单,你只需要在方括号里列出它们就行了,像[aeiou]就匹配任何一个英文元音字母,[.?!]匹配标点符号(.或?或!)。
我们也可以轻松地指定一个字符范围,像[0-9]代 表的含意与d就是完全一致的:一位数字; 同理[a-z0-9A-Z_]也完全等同于w(如 果只考虑英文的话)。
下面是一个更复杂的表达式:(?0d{2}[) -]?d{8}。
“(”和“)”也是元字符,后面的分 组节里会提到,所以在这里需要使用转 义。
这个表达式可以匹配几种格式的电话号码,像(010)88886666, 或022-22334455,或02912345678等。 我们对它进行一些分析吧:首先是一个转义字符(,它能出现0次或1次(?),然后是一个0,后面跟着2个数字(d{2}),然后是)