正则表达式
定义是一组描述字符串特征的字符 作用用来检查一个串是否含有某种子串、将匹配的子串做替换或者从某个串中取出符合某个条件的子串等 语法使用斜杠作为定界符,如 /[-a-z]/。正则表达式分为普通字符和元字符,普通字符分为打印字符和非打印字符,打印字符包括字母字符、数字、标点及一些其他符号,非打印字符指打印到纸张上后不可见的字符,包括空格符、回车符、制表符、垂直制表符、换行符、换页符等。元字符指在正则表达式中有特殊含义的字符包括定界符、定位符、限定符、转义符、选择符等。 $subject='< a1>expressions< a1>'; $pattern='/<.*>/'; $res=preg_match_all($pattern,$subject,$matches); echo $matches[0][0];//结果为 < a1>expressions< a1> $res=preg_match_all('/<.*?>/',$matches); echo $matches[0][0];//结果为 < a1> 定位符用来描述字符串或单词的边界,也就是指单词和空格间的位置,^和$分别指字符串的开始与结束,b描述单词的前或后边界,B表示非单词边界。不能对定位符使用限定符。例如, 'erb' 可以匹配"a never aa" 中的 'er',但不能匹配 "a verb" 中的 'er'。'erB' 能匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。 选择符圆括号用来使被括起来的部分最为一个整体存在,可以用限定符修饰,如 (aa)*,同时被括起来的部分也会成为一个子表达式被缓存起来用于后面的引用,如 (aa)b1可以匹配 aabaa或aabaac,另外引用时最大只能到99,意思就是缓冲区最多只能放99个子表达式,如果不需要进行引用则可以用?:禁用缓存,如 'industr(?:y|ies) 就是一个比 'industry|industries' 更简略的表达式 。其中?:是非捕获元字符之一,还有两个非捕获元字符是?=和?! 操作符的运算优先级由高到低依次为 转义符、圆括号和方括号、限定符、定位符和普通字符、"或"操作符,如,普通字符具有高于替换运算符的优先级,使得"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 - 仅检查某个字符串是否包含另外一个字符串 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |