最近整体学习了一下正则表达式的知识,发现还是在例子中进行学习效率比较高,接下来分享一下正则表达式的经典例子并进行相关知识点的总结。
例子1:匹配5-12位的数字:^\d{5,12}$
首先介绍两个特殊符号,^表示字串开头,$表示字串结尾,这两个用来限定匹配的范围。接下来\d用来匹配一个数字,后面可以接一个{},里面输入数字。当输入一个数字时,比如{3},表示对数字进行3次匹配;当输入两个数字如例子中那样,表示匹配5-12次均可。
例子2:匹配以字母a开头的单词:\ba\w*\b
在正则表达式中可以直接使用字符来进行匹配,比如使用a就表示匹配带a字母的模式。\b表示字符的 边缘。\w表示匹配除了空格以外的一切字符。在正则表达式中可以使用一些符号表示匹配多少次,其中*表示匹配0-N次,+表示匹配1-N次,?表示匹配0或1次。所以上面的例子中\w*表示a后面接着0或多个字符。因此整个模式匹配的就是以a开头的字符。
例子3:匹配座机电话号码:\(?0\d{2}[) -]?\d[8]
这个正则表达式匹配的是形如(010)88886666或者022-22334455这类的电话号码。首先要注意,因为(?等符号在正则表达式中都有特殊的意义,因此要使用真正的这类符号的时候需要进行转意。这个例子中最开始的\)?就表示(出现0次或1次。接下来是区号,因为区号是3位数字并且开头的数字必须为0,因此使用0\d{2}就可以完美匹配这个要求。然后是[]的使用。[]内可以放入多个值,表示下一位匹配的是这其中字符中的一个。比如这里的[) -]?就表示匹配左括号、空格或者-中的一个,匹配0次或1次。最后再使用\d{8}匹配8位数字即可符合要求。
例子4:匹配以ing结尾的单词的前面部分:\b\w+(?=ing\b)
这里面使用了零宽断言,零宽断言中的(?=exp)表示匹配后面的要求的前面的部分。本例中的(?=ing\b)匹配的就是要以ing结尾的字符。
原文:http://blog.csdn.net/fareise/article/details/52068028