实用软件资讯

正则表达式30分钟入门教程

$ 匹配字符串的结束

元字符^(和数字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.comC:Windows匹配C:Windows

重复

你已经看过了前面的*,+,{2},{5,12}这几个匹配重复的方式了。下面是 正则表达式中所有的限定符(指定数量的代码,例如*,{5,12}等):

表2.常用的限定符
代码/语法 说明
* 重复零次或更多次
+ 重复一次或更多次
? 重复零次或一次
{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}),然后是)

希望看到您的想法,请您发表评论x