PHP中的正则表达式函数介绍
2024-05-04 22:05:20
供稿:网友
正则表达式(Regular Expression)
正则表达式系统:
1.POSIX
2.Perl
PHP中使用的regex是PCRE:
NOTE:PCRE(Perl兼容正则表达式,Perl Compatible Regular Expressions)
PCRE语法:
1.定界符
必须成对出现,可以使用除0-9a-zA-Z/以外的任何字符
2.原子
1.正则需要匹配的可见和不可见字符都是原子
2.一个正则表达式最少含有一个原子
3.当需要匹配诸如"("、"["、"^"等含有语义的符号时需要用"/"反斜线进行转义
原子字符:
/f 匹配换页符
/n 匹配换行符
/r 匹配回车符
/t 匹配制表符
/v 匹配垂直制表符
3.元字符
/ 转义字符
^ 匹配字符串起始处
$ 匹配字符串末尾
. 匹配除"/n"之外的任何单个字符
* 匹配前面的子表达式0或多次
+ 匹配前面的子表达式1次或多次
? 匹配前面的子表达式0次或1次
{n} 匹配n次
{n,} 匹配n次或n次以上
{n,m} 最少匹配n次至多匹配m次,(n<=m)
[] 中括号代表原子表,中间的原子地位都是相等。在匹配的时候,匹配表中的任意一个字符
[^] 抑扬符,排除后面的原子表所包含的字符。
(pattern) 匹配pattern并获取这一匹配。
/num 对获取的第num个匹配的引用。
(?:pattern) 匹配pattern但不获取这一匹配
(?=pattern) 正向肯定预查,非获取匹配,例如:windows(?=XP|7)能匹配windowsXP中的windows不能匹配windows98中的windows
(?!=pattern) 正向否定欲查非获取匹配,例如:windows(?!98|2000),能匹配windowsXP中的windows,不能匹配windows98中的windows
(?<=pattern) 反向肯定预查,非获取匹配。例如:(?<=My|Postgre)SQL能匹配MySQL中的SQL,不能匹配MSSQL中的SQL
(?<!pattern) 反向否定预查,非获取匹配。例如:(?<!My|Postgre)SQL能匹配MSSQL中的SQL,不能匹配MySQL中的SQL
/b 匹配单词边界
/B 匹配除单词边界以外的字符
/d 匹配任何一个数字。等价于[0-9]
/D 匹配任何一个非数字以外的字符。等价于[^0-9]
/s 匹配任何一个空白字符(包括空格、制表符、换页符等)。等价于[/f/n/r/t/v]
/S 匹配任何一个非空白字符。等价于[^/f/n/r/t/v]
/w 匹配任何一个数字、字母或下划线。等价于[0-9a-zA-Z]
/W 匹配任何一个非数字、字母或下划线的字符。等价于[^0-9a-zA-Z]