一、语法
1.例如:

①^ 为匹配输入字符串的开始位置。
②[0-9]+匹配多个数字, [0-9] 匹配单个数字,+ 匹配一个或者多个。
③abc$匹配字母 abc 并以 abc 结尾,$ 为匹配输入字符串的结束位置。
写用户注册表单时,只允许用户名包含字符、数字、下划线和连接字符 -,并设置用户名的长度,我们就可以使用以下正则表k达式来设定:

2.符号+ * ?的区别
runoo+b,可以匹配 runoob、runooob、runoooooob 等,+ 号代表前面的字符可以出现1~n次。

runoo*b,可以匹配 runob、runoob、runoooooob 等,* 号代表前面的字符可以出现0~n次。

colou?r 可以匹配 color 或者 colour,? 问号代表前面的字符可以出现0~1次。

正则表达式是由普通字符(例如字符 a 到 z)以及特殊字符(称为"元字符")组成的文字模式。模式描述在搜索文本时要匹配的一个或多个字符串。正则表达式作为一个模板,将某个字符模式与所搜索的字符串进行匹配。
3.普通字符
普通字符包括没有显式指定为元字符的所有可打印和不可打印字符。这包括所有大写和小写字母、所有数字、所有标点符号和一些其他符号。






\d:匹配一个数字字符,等价于 [0-9](\D匹配一个非数字字符,等价于[^0-9])
4.非打印字符

5.特殊字符
所谓特殊字符,就是一些有特殊含义的字符,如上面说的 runoo*b 中的 *,简单的说就是表示任何字符串的意思。如果要查找字符串中的 * 符号,则需要对 * 进行转义,即在其前加一个 \,runo\*ob 匹配字符串 runo*ob。
许多元字符要求在试图匹配它们时特别对待。若要匹配这些特殊字符,必须首先使字符"转义",即,将反斜杠字符\ 放在它们前面。下表列出了正则表达式中的特殊字符:

6.限定符
限定符用来指定正则表达式的一个给定组件必须要出现多少次才能满足匹配。有 * 或 + 或 ? 或 {n} 或 {n,} 或 {n,m} 共6种。正则表达式的限定符有:

7.定位符
定位符将正则表达式固定到行首或行尾。它们还使您能够创建这样的正则表达式,这些正则表达式出现在一个单词内、在一个单词的开头或者一个单词的结尾。

注意:不能将限定符与定位符一起使用。由于在紧靠换行或者单词边界的前面或后面不能有一个以上位置,因此不允许诸如 ^* 之类的表达式。
若要匹配一行文本开始处的文本,请在正则表达式的开始使用 ^ 字符。不要将 ^ 的这种用法与中括号表达式内的用法混淆。若要匹配一行文本的结束处的文本,请在正则表达式的结束处使用 $ 字符。
8.选择
() 表示捕获分组,() 会把每个分组里的匹配的值保存起来, 多个匹配值可以通过数字 n 来查看(n 是一个数字,表示第 n 个捕获组的内容)。用圆括号 () 将所有选择项括起来,相邻的选择项之间用 | 分隔。

圆括号会有一个副作用,使相关的匹配会被缓存,此时可用 ?: 放在第一个选项前来消除这种副作用。
其中 ?: 是非捕获元之一,还有两个非捕获元是 ?= 和 ?!,这两个还有更多的含义,前者为正向预查,在任何开始匹配圆括号内的正则表达式模式的位置来匹配搜索字符串,后者为负向预查,在任何开始不匹配该正则表达式模式的位置来匹配搜索字符串。
先行断言(lookahead)和后行断言(lookbehind):
1.(?=pattern) 正向先行断言:代表字符串中的一个位置,紧接该位置之后的字符序列能够匹配 pattern
匹配 regular 中的 re,但不能匹配 expression 中的 re:

2.(?!pattern) 负向先行断言:代表字符串中的一个位置,紧接该位置之后的字符序列不能匹配 pattern。

3.(?<=pattern) 正向后行断言:代表字符串中的一个位置,紧接该位置之前的字符序列能够匹配 pattern。

4.(?<!pattern) 负向后行断言:代表字符串中的一个位置,紧接该位置之前的字符序列不能匹配 pattern。

二、修饰符

三、元字符




四、运算符优先级

通用字符簇

五、正则捕获组
1.1、概述
捕获组就是把正则表达式中子表达式匹配的内容,保存到内存中以数字编号或显式命名的组里,方便后面引用。当然,这种引用既可以是在正则表达式内部,也可以是在正则表达式外部。
捕获组有两种形式,一种是普通捕获组,另一种是命名捕获组,通常所说的捕获组指的是普通捕获组。语法如下:
普通捕获组:(Expression)
命名捕获组:(?<name>Expression)
普通捕获组在大多数支持正则表达式的语言或工具中都是支持的,而命名捕获组目前只有.NET、PHP、Python等部分语言支持,据说Java会在7.0中提供对这一特性的支持。上面给出的命名捕获组的语法是.NET中的语法,在PHP和Python中命名捕获组语法为:(?P<name>Expression)。
另外需要说明的一点是,除(Expression)和(?<name>Expression)语法外,其它的(?...)语法都不是捕获组。
1.2捕获组编号规则
编号规则指的是以数字为捕获组进行编号的规则,在普通捕获组或命名捕获组单独出现的正则表达式中,编号规则比较清晰,在普通捕获组与命名捕获组混合出现的正则表达式中,捕获组的编号规则稍显复杂。
在展开讨论之前,需要说明的是,编号为0的捕获组,指的是正则表达式整体,这一规则在支持捕获组的语言中,基本上都是适用的。下面对其它编号规则逐一展开讨论。


1.2.1普通捕获组与命名捕获组混合编号规则
当一个正则表达式中,普通捕获组与命名捕获组混合出现时,捕获组的编号规则稍显复杂。对于其中的命名捕获组,随时都可以通过组名进行访问,而对于普通捕获组,则只能通过确定其编号后进行访问。
混合方式的捕获组编号,首先按照普通捕获组中“(”出现的先后顺序,从左到右,从1开始进行编号,当普通捕获组编号完成后,再按命名捕获组中“(”出现的先后顺序,从左到右,接着普通捕获组的编号值继续进行编号。也就是先忽略命名捕获组,对普通捕获组进行编号,当普通捕获组完成编号后,再对命名捕获组进行编号。


2.捕获组的引用
科学计数法:"^([+-]?[0-9]+(.{0}|.[0-9]+))[Ee]{1}([+-]?[0-9]+)$";
数字: "^[+-]?([0-9]+|[0-9]+\\.[0-9]+)$";
