定义

是一组描述字符串特征的字符

作用

用来检查一个串是否含有某种子串、将匹配的子串做替换或者从某个串中取出符合某个条件的子串等

语法

使用斜杠作为定界符,如 /[-a-z]/。正则表达式分为普通字符和元字符,普通字符分为打印字符和非打印字符,打印字符包括字母字符、数字、标点及一些其他符号,非打印字符指打印到纸张上后不可见的字符,包括空格符、回车符、制表符、垂直制表符、换行符、换页符等。元字符指在正则表达式中有特殊含义的字符包括定界符、定位符、限定符、转义符、选择符等。
限定符用来限定元素出现的次数,有 ? + * {n} {n,} {n,m} 共6种。限定符的默认模式是贪婪模式,贪婪模式会尽可能多的匹配字符,在它们的后面加上一个?就会变成非贪婪模式,非贪婪模式会尽可能少的匹配字符,如

$subject='< a1>expressions< a1>';
$pattern='/<.*>/';
$res=preg_match_all($pattern, $subject,$matches);
echo $matches[0][0];//结果为  < a1>expressions< a1>
$res=preg_match_all('/<.*?>/', $subject,$matches);
echo $matches[0][0];//结果为  < a1>

定位符

用来描述字符串或单词的边界,也就是指单词和空格间的位置,^和$分别指字符串的开始与结束,\b描述单词的前或后边界,\B表示非单词边界。不能对定位符使用限定符。例如, 'er\b' 可以匹配"a never aa" 中的 'er',但不能匹配 "a verb" 中的 'er'。'er\B' 能匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。

选择符

圆括号用来使被括起来的部分最为一个整体存在,可以用限定符修饰,如 (aa)* ,同时被括起来的部分也会成为一个子表达式被缓存起来用于后面的引用,如 (aa)b\1可以匹配 aabaa或aabaac,另外引用时最大只能到\99,意思就是缓冲区最多只能放99个子表达式,如果不需要进行引用则可以用?:禁用缓存,如 'industr(?:y|ies) 就是一个比 'industry|industries' 更简略的表达式 。其中?:是非捕获元字符之一,还有两个非捕获元字符是?=和?!
(?=pattern) 正向预查,在任何匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。例如,'Windows (?=95|98|NT|2000)' 能匹配 "Windows 2000" 中的 "Windows" ,但不能匹配 "Windows 3.1" 中的 "Windows"。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始;
(?!pattern) 负向预查,在任何不匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。例如'Windows (?!95|98|NT|2000)' 能匹配 "Windows 3.1" 中的 "Windows",但不能匹配 "Windows 2000" 中的 "Windows"。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始

操作符的运算优先级

由高到低依次为 转义符、圆括号和方括号、限定符、定位符和普通字符、"或"操作符,如,普通字符具有高于替换运算符的优先级,使得"m|food"匹配"m"或"food"。若要匹配"mood"或"food",请使用括号创建子表达式,即"(m|f)ood"

PHP中和正则表达式相关的函数

preg_quote - 转义正则表达式字符
preg_match — 执行正则表达式
preg_match_all - 执行一个全局正则表达式
preg_replace - 执行一个正则表达式并替换匹配内容
preg_​filter 等价于preg_replace() 除了它仅仅返回(可能经过转化)与目标匹配的结果
preg_replace_callback - 执行一个正则表达式搜索并且使用一个回调进行替换
preg_replace_callback_array - 执行一个正则表达式搜索并且使用一个回调进行替换
preg_split - 通过一个正则表达式分隔字符串
preg_last_error - 返回最后一个PCRE正则执行产生的错误代码
preg_​grep 返回给定数组input中与模式pattern匹配的元素组成的数组
strpos - 仅检查某个字符串是否包含另外一个字符串


jamesnet
28 声望0 粉丝

a bug