正则表达式

hi \bhi\b
.不换行 任意数量 \bhi\b.\blucy\b
^\d{5,12}$
转义 . * \
查找的集合 [?!][aeio]
或者 \d{5}-\d{4}|\d{5}
(){3} 3次 (\d{1,3}.){3}\d{1,3}
IP地址 ((2[0-4]\d|25[0-5]|[01]?\d?\d).){3}(2[0-4]\d|25[0-5]|[01]?\d?\d)
不包含空白符字符串 \S+
<a[^>]+> 用尖括号括起来以a开头字符串
★分组
\1第一组 \b(\w+)\b\s+\1\b
组名为Word \b(?\w+)\b\s+\k\b
★断言
\b\w+(?=ing\b) 以ing结尾的单词的前面部分
(?<=\bre)\w+\b 以re开头的单词的后半部分
\b((?!abc)\w)+\b 不包含连续字符串abc的单词
(?<=<(\w+)>).*(?=</\1>) 不包含属性的简单HTML标签内里的内容
★注释
(?#comment) 乱的话:启用“忽略模式里的空白符”选项,来自行调整格式

贪婪与懒惰

a.b aabab 匹配到aabab(贪婪)
a.
?b aabab 匹配到aab 和ab
★平衡组/递归匹配
(?R) 引用整个表达式
(?'group') 把捕获的内容命名为group,并压入堆栈(Stack)
(?'-group') 从堆栈上弹出最后压入堆栈的名为group的捕获内容,如果堆栈本来为空,则本分组的匹配失败
(?(group)yes|no) 如果堆栈上存在以名为group的捕获内容的话,继续匹配yes部分的表达式,否则继续匹配no部分
(?!) 零宽负向先行断言,由于没有后缀表达式,试图匹配总是失败

常用的元字符: 常用的限定符:
. 匹配除换行符以外的任意字符 * 重复零次或更多次0
\w 匹配字母或数字或下划线或汉字 + 重复一次或更多次1
\s 匹配任意的空白符 ? 重复零次或一次 0 or 1
\d 匹配数字,多个:\d{2} {n} 重复n次
\b 匹配单词的开始或结束 {n,} 重复n次或更多次
^ 匹配字符串的开始 {n,m} 重复n到m次
$ 匹配字符串的结束
常用的反义代码:
\W 匹配任意不是字母,数字,下划线,汉字的字符
\S 匹配任意不是空白符的字符
\D 匹配任意非数字的字符
\B 匹配不是单词开头或结束的位置
[^x] 匹配除了x以外的任意字符
[^aeiou] 匹配除了aeiou这几个字母以外的任意字符
常用的分组语法:
捕获 (exp) 匹配exp,并捕获文本到自动命名的组里
(?exp) 匹配exp,并捕获文本到名称为name的组里,也可以写成(?'name'exp)
(?:exp) 匹配exp,不捕获匹配的文本,也不给此分组分配组号
零宽断言 (?=exp) 匹配exp前面的位置
(?<=exp) 匹配exp后面的位置
(?!exp) 匹配后面跟的不是exp的位置
(?<!exp) 匹配前面不是exp的位置
注释 (?#comment) 这种类型的分组不对正则表达式的处理产生任何影响,用于提供注释让人阅读
懒惰限定符
*? 重复任意次,但尽可能少重复
+? 重复1次或更多次,但尽可能少重复
?? 重复0次或1次,但尽可能少重复
{n,m}? 重复n到m次,但尽可能少重复
{n,}? 重复n次以上,但尽可能少重复
常用的处理选项:
IgnoreCase(忽略大小写) 匹配时不区分大小写。
Multiline(多行模式) 更改^和$的含义,使它们分别在任意一行的行首和行尾匹配,而不仅仅在整个
字符串的开头和结尾匹配。(在此模式下,$的精确含意是:匹配\n之前的位置以及
字符串结束前的位置.)
Singleline(单行模式) 更改.的含义,使它与每一个字符匹配(包括换行符\n)。
IgnorePatternWhitespace 忽略表达式中的非转义空白并启用由#标记的注释。
(忽略空白)
ExplicitCapture(显式捕获) 仅捕获已被显式命名的组。

其他
\a 报警字符(打印它的效果是电脑嘀一声)
\b 通常是单词分界位置,但如果在字符类里使用代表退格
\t 制表符,Tab
\r 回车
\v 竖向制表符
\f 换页符
\n 换行符
\e Escape
\0nn ASCII代码中八进制代码为nn的字符
\xnn ASCII代码中十六进制代码为nn的字符
\unnnn Unicode代码中十六进制代码为nnnn的字符
\cN ASCII控制字符。比如\cC代表Ctrl+C
\A 字符串开头(类似^,但不受处理多行选项的影响)
\Z 字符串结尾或行尾(不受处理多行选项的影响)
\z 字符串结尾(类似$,但不受处理多行选项的影响)
\G 当前搜索的开头
\p{name} Unicode中命名为name的字符类,例如\p{IsGreek}
(?>exp) 贪婪子表达式
(?-exp) 平衡组
(?im-nsx:exp) 在子表达式exp中改变处理选项
(?im-nsx) 为表达式后面的部分改变处理选项
(?(exp)yes|no) 把exp当作零宽正向先行断言,如果在这个位置能匹配,使用yes作为此组的表达式;否则使用no
(?(exp)yes) 同上,只是使用空表达式作为no
(?(name)yes|no) 如果命名为name的组捕获到了内容,使用yes作为表达式;否则使用no
(?(name)yes) 同上,只是使用空表达式作为no

/ 表达式的开始
/i (忽略大小写)
/g (全文查找出现的所有匹配字符)
/m (多行查找)
/gi(全文查找、忽略大小写)
/ig(全文查找、忽略大小写)
/s 与/m相对,单行模式匹配。
/e 可执行模式,此为PHP专有参数,例如preg_replace函数。
/x 忽略空白模式。、
/e
$subject = '

4+5=${4+5}

';
$str = preg_replace('/${(.+)}/e', '$1', $subject);
echo $str.PHP_EOL;
//运行结果为:

4+5=9

,因为'$1'中匹配出来的是'4+5'当做php表达式执行了。

posted @ 2021-02-28 11:18  plesesmile  阅读(96)  评论(0编辑  收藏  举报