网站首页 » PHP » 正则表达式

正则表达式

June 19, 2020 PHP

正则表达式要点

行定位符(^与$)
行定位符是用来描述字符串的边界。 “$”表示行结尾 “^”表示行开始如 "^de",表示以de开头的字符串 "de$",表示以de结尾的字符串。

单词定界符
我们在查找的一个单词的时候,如an是否在一个字符串”gril and body”中存在,很明显如果匹配的话,an肯定是可以匹配字符串“gril and body”匹配到,怎样才能让其匹配单词,而不是单词的一部分呢?这时候,我们可以是哟个单词定界符。
an 去匹配”gril and body”的话,就会提示匹配不到。
当然还有一个大写的B,它的意思,和正好相反,它匹配的字符串不能使一个完整的单词,而是其他单词或字符串中的一部分。如BanB。

选择字符(|) ,表示或
选择字符表示或的意思。如Aa|aA,表示Aa或者是aA的意思。注意使用”[]”与”|”的区别,在于”[]”只能匹配单个字符,而”|”可以匹配任意长度的字符串。在使用”[]”的时候,往往配合连接字符”-“一起使用,如[a-d],代表a或b或c或d。

排除字符,排除操作
正则表达式提供了”^”来表示排除不符合的字符,^一般放在[]中。如1,该字符不是1~5之间的数字。

限定符(?*+{n,m})
限定符主要是用来限定每个字符串出现的次数。

限定字符 含义
? 零次或一次

  • 零次或多次
  • 一次或多次

{n} n次
{n,} 至少n次
{n,m} n到m次
如(D+)表示一个或多个D

点号操作符
匹配任意一个字符(不包含换行符)

表达式中的反斜杠( )
表达式中的反斜杠有多重意义,如转义、指定预定义的字符集、定义断言、显示不打印的字符。

转义字符
转义字符主要是将一些特殊字符转为普通字符。而这些常用特殊字符有”.”,”?”、””等。

指定预定义的字符集
字符 含义
d 任意一个十进制数字[0-9]
D 任意一个非十进制数字2
s 任意一个空白字符(空格、换行符、换页符、回车符、字表符)[ f

v]

S 任意一个非空白字符[^ f

v]

w 任意一个单词字符[A-Za-z0-9_]
W 任意个非单词字符3
不可打印的字符
字符 含义
a 报警
 退格
f 换页

换行
回车
    字表符

括号字符()
在正则表达式中小括号的作用主要有:

改变限定符如(|、* 、^)的作用范围
如(my|your)baby,如果没有”()”,|将匹配的是要么是my,要么是yourbaby,有了小括号,匹配的就是mybaby或yourbaby。
进行分组,便于反向引用
反向引用
反向引用,就是依靠子表达式的”记忆”功能,匹配连续出现的字串或是字符。如(dqs)(pps)12,表示匹配字符串dqsppsdqspps。

模式修饰符
模式修饰符的作用是设定模式,也就是正则表达式如何解释。php中主要模式如下表:

修饰符 说明
i 忽略大小写
m 多文本模式
s 单行文本模式
x 忽略空白字符
贪婪匹配与惰性匹配
贪婪匹配:就是匹配尽可能多的字符。
比如,正则表达式中m.*n,它将匹配最长以m开始,n结尾的字符串。如果用它来搜索manmpndegenc的话,它将匹配到的字符串是manmpndegen而非man。可以这样想,当匹配到m的时候,它将从后面往前匹配字符n。
懒惰匹配:就是匹配尽可能少的字符。
有的时候,我们需要并不是去贪婪匹配,而是尽可能少的去匹配。这时候,就需要将其转为惰性匹配。怎样将一个贪婪匹配转为惰性匹配呢?只需要在其后面添加一个”?”即可。如m.*?n将匹配manmpndegenc,匹配到的字符串是man。
函数符 描述
*? 零次或多次,但尽可能少的匹配
+? 一次或多次,但尽可能少的匹配
?? 0次或1次,但尽可能少的匹配
{n,}? 至少n次,但尽可能少的匹配
{n,m}? n到m次 ,但尽可能少的匹配


  1. 1-5
  2. 0-9
  3. A-Za-z0-9_
添加新评论