正则表达式的学习

正则基础

\b    是正则表达式的一个特殊代码,有人称它元字符。代表的是需要匹配的某个单词的开头或者结尾。有些单词有空格或者分隔符,但是\b并不管这些,它只匹配一个位置,也就是说,空格,分隔符它也比较。

.    是另一个元字符,表示匹配除了换行符以外的任意字符。

*    也是一个元字符,不过它代表的不是字符,也不是位置,而是数量。它制定*字符前边的内容可以连续重复使用任意次以使整个表达式得以匹配。

.*    连在一起,就表示任意数量除了换行以外的任意字符。

例子:\bhi\b.*\bLucy\b表示以hi开头,中间任意数量除换行以外的任意字符,并且以Lucy结尾。

\d    是一个新的元字符,匹配任意一个数字(可以是0,可以是1...)

-    不是元字符,其实它就只匹配它本身,可以称它链接符,也可以称它减号,由自己啦!

例子:0\d\d-\d\d\d\d\d\d\d表示0开头,后跟2个任意数字,接着是链接-,最后是7个任意数字。当然,避免重复,可以简化写出0\d{2}-\d{7}

\s    表示匹配任意空白符,包括空格,制表符(tab),换行符,中文全角空格等。

\w    匹配字母,数字,下划线,或者汉字等。

^    匹配字符串开始。

$    匹配字符串结束。

例子:

\ba\w*\b匹配以字母a开头的单词——先是某个单词开始处(\b),然后是字母a,然后是任意数量的字母或数字(\w*),最后是单词结束处(\b)。

\d+匹配1个或更多连续的数字。这里的+是和*类似的元字符,不同的是*匹配重复任意次(可能是0次),而+则匹配重复1次或更多次。

\b\w{6}\b匹配刚好6个字符的单词。

{n}    重复N次

{n, }    重复n次到更多次

{n,m}    重复n到m次

{5,12}    表示重复的次数不能少于5次,不能多于12次。

例子:^\d{5,12}$匹配一个5-12位的数字。

\    表示转义符。比如你要匹配字符串中的.或者*等等,匹配不到,可以用\.或者\*当然,你要匹配\的话,就用\\

+    和*相似,但是+表示重复一次或多次。

?    重复0次或1次。

[ ]    指定一个范围。[0-9]表示一位数字,[a-zA-Z]

例子:\(?0\d{2}[) -]?\d{8}这个表达式可以匹配几种格式的电话号码,像(010)88886666,或022-22334455,或02912345678等。我们对它进行一些分析吧:首先是一个转义字符\(,它能出现0次或1次(?),然后是一个0,后面跟着2个数字(\d{2}),然后是)或-或空格中的一个,它出现1次或不出现(?),最后是8个数字(\d{8})。

不幸的是,上面那个例子也能匹配010)12345678或(022-87654321这样的“不正确”的格式。要解决这个问题,我们需要用到分枝条件。正则表达式里的分枝条件指的是有几种规则,如果满足其中任意一种规则都应该当成匹配,具体方法是用|把不同的规则分隔开。

|    分割不同的规则,但是使用时候要严格注意匹配顺序,因为如果符合第一个条件,就不会审核第二个条件了。

例子:0\d{2}-\d{8}|0\d{3}-\d{7}这个表达式能匹配两种以连字号分隔的电话号码:一种是三位区号,8位本地号(如010-12345678),一种是4位区号,7位本地号(0376-2233445)。

\(?0\d{2}\)?[-]?\d{8}|0\d{2}[- ]?\d{8}这个表达式匹配3位区号的电话号码,其中区号可以用小括号括起来,也可以不用,区号与本地号间可以用连字号或空格间隔,也可以没有间隔。

\d{5}-\d{4}|\d{5}如果你把它改成\d{5}|\d{5}-\d{4}的话,那么就只会匹配5位的邮编(以及9位邮编的前5位)。原因是匹配分枝条件时,将会从左到右地测试每个条件,如果满足了某个分枝的话,就不会去再管其它的条件了。

( )    重复多个字符,用()来指定子表达式,也可以叫做分组,可以指定( )中的元素重复多次。

例子:((2[0-4]\d|25[0-5]|[01]?\d\d?)\.){3}(2[0-4]\d|25[0-5]|[01]?\d\d?)判断正确的IP地址

\W    匹配任意不是字母,数字,下划线,汉字的字符

\S    匹配任意不是空白符的字符

\D    匹配任意非数字的字符

\B    匹配不是单词开头或结束的位置

[^x]    匹配除了x以外的任意字符

[^aeiou]    匹配除了aeiou这几个字母以外的任意字符

例子:\S+匹配不包含空白符的字符串。

]+>    匹配尖括号开始包含a打头字母的字符串。

正则匹配进阶

后向引用

使用小括号指定一个子表达式后,匹配这个子表达式的文本(也就是此分组捕获的内容)可以在表达式或其它程序中作进一步的处理。默认情况下,每个分组会自动拥有一个组号,规则是:从左向右,以分组的左括号为标志,第一个出现的分组的组号为1,第二个为2,以此类推。

后向引用用于重复搜索前面某个分组匹配的文本。例如,\1代表分组1匹配的文本。

例子:\b(\w+)\b\s+\1\b可以用来匹配重复的单词,像go go,或者kitty kitty。这个表达式首先是一个单词,也就是单词开始处和结束处之间的多于一个的字母或数字(\b(\w+)\b),这个单词会被捕获到编号为1的分组中,然后是1个或几个空白符(\s+),最后是分组1中捕获的内容(也就是前面匹配的那个单词)(\1)。

捕获

(exp)    匹配exp,并捕获文本到自动命名的组里

(?exp)    匹配exp,并捕获文本到名称为name的组里,也可以写成(?'name'exp)

(?:exp)    匹配exp,不捕获匹配的文本,也不给此分组分配组号

引用

\k(Word)反向引用这个分组捕获的内容

零宽断言

(?=exp)    匹配exp前面的位置

(?<=exp)    匹配exp后面的位置

(?!exp)    匹配后面跟的不是exp的位置

注释

(?#comment)  这种类型的分组不对正则表达式的处理产生任何影响,用于提供注释让人阅读

例子:\b(\w+)\b\s+\1\b通过上面介绍,可以改写成\b(?\w+)\b\s+\k\b

你可能感兴趣的:(正则表达式的学习)