正则这个小东东
需要我们用程序处理的数据并不总是预先以数据库思维设计的,或者说是无法用数据库的结构去存储的。 比如模版引擎解析模版、垃圾敏感信息过滤等等。 一般这种情况,我们用正则按我们的规则去匹配preg_match、替换preg_replace。 但一般的应用中,无非是些数据库CRUD,正则摆弄的机会很少。 根据前面说的,两种场景:统计分析,用匹配;处理用替换。 下面是对网上一篇文章的整理,写得很好,不得不转一下。http://e.v-get.com/w3c/PHP_preg_replace.html 其实,这篇文章可能只是他用于做SEO的,但内容整理得确实很有诚意。 PHP preg_replace() 正则替换,与preg_match()只匹配一次不同,preg_replace() 默认就是替换所有符号匹配条件的内容。 preg_replace (正则表达式,替换成,字符串,最大替换次数【默认-1,无数次】,替换次数) 商标中的正则字符都有特殊含义,已经不再代表原字符含义。如正则表达式中“+”不代表加号,而是代表匹配一次或多次。而如果想要让“+”表示加号,则需要在其前面加上“”转义,也就是用“+”表示加号。 1+1=2 正则表达式是: 1+1=2 而正则表达式 1+1=2 可以代表,多个1=2,即: 11=2 正则表达式:1+1=2 111=2 正则表达式:1+1=2 1111=2 正则表达式:1+1=2 ……
也就是说所有正则字符都有特定含义,如果需要再用来表示原字符含义,就需要在前面加“”转义,即使非正则字符,用“”转义也是没有问题的。 1+1=2 正则表达式也可以是: 1+1=2 对所有字符都转义,但是这种不建议使用。
而正则表达式必须要使用定界符包围起来,在Javascript中定界符是“/”,在PHP中,比较常见的是用“/”定界,也可以用“#”定界,而且外面还需要用引号包围起来。 如果正则表达式包含这些定界符,就需要对这些字符进行转义。 PHP 正则表达式定界符大多数语言的正则表达式都是由“/”作为定界符的,而在PHP中,还可以使用“#”定界,如果字符串中包含大量“/”字符,在使用“/”定界的时候,就需要对这些“/”转义,而使用“#”就不需要转义,更简洁。 <?php $weigeti='W3CSchool 在线教程的网址是 http://e.v-get.com/ ,你能把这个网址替换成正确的网址吗?'; // 上面的要求就是把http://e.v-get.com/ 替换成 http://e.v-get.com/w3c/ // . : - 都是正则符号,所以需要转义,而 / 是定界符,如果字符串中包含 / 定界符,就需要转义 echo preg_replace('/http://e.v-get.com//','http://e.v-get.com/w3c/',$weigeti); // 在 #作为定界符,/ 就不再是定界符的含义,就不需要转义了。 echo preg_replace('#http://e.v-get.com/#',$weigeti); //上面两条输出结果都一样,【W3CSchool 在线教程的网址是 http://e.v-get.com/w3c/ ,你能把这个网址替换成正确的网址吗?】 ?> 通过上面的两条PHP 正则替换代码我们可以发现,如果正则语句中包含大量“/”,无论使用“/” 还是 “#”做定界符都是可以的,但是使用“#”能让代码看起来更简洁。但是E维科技建议您还是保持使用“/”作为定界符,因为在Javascript等语言中,只能使用“/”作为定界符,这样写起来可以形成习惯,贯通于其他语言中。 PHP 正则表达式修饰符修饰符被放在PHP正则表达式定界符“/”尾部,在正则表达式尾部引号之前。
如果您熟悉Javascript 的正则表达式,或许一定熟悉Javascript 正则表达式的修饰符“g”,代表匹配所有符合条件的元素。而在PHP 正则替换中,是匹配所有符号条件的元素,所以不存在Javascript 修饰符“g”。 PHP 正则中文和忽略大小写PHP preg_replace() 是区分大小写的,同时只能匹配ASCII编码内的字符串,如果需要匹配不区分大小写和中文等字符需要添加相应的修饰符 i 或 u。 <?php $weigeti='W3CSchool 在线教程网址:http://e.v-get.com/w3cschool/'; echo preg_replace('/W3CSchool/','w3c',$weigeti); //大小写不同,输出【w3c 在线教程网址:http://e.v-get.com/w3cschool/】 echo preg_replace('/W3CSchool/i',$weigeti); //忽略大小写,执行替换输出【w3c 在线教程网址:http://e.v-get.com/w3c/】 echo preg_replace('/网址/u','',$weigeti); //强制 UTF-8中文,执行替换,输出【W3CSchool 在线教程:http://e.v-get.com/w3cschool/】 ?> 大小写和中文在PHP中都是敏感的,但是在Javascript正则中,只对大小写敏感,忽略大小写也是通过修饰符 i 作用的,但是Javascript 不需要告知是否是UTF-8中文等特殊字符,直接可以匹配中文。 PHP 正则换行符实例PHP 正则表达式在遇到换行符时,会将换行符当做字符串中间一个普通字符。而通用符号.不能匹配n,所以遇到带有换行符的字符串正则会有很多要点。 <?php $weigeti="V-Get.comnISnLOVINGnYOU"; // 想要把上面$weigeti 替换成V-Get.com echo preg_replace('/^[A-Z].*[A-Z]$/',$weigeti); // 这个正则表达式是,匹配只包含w的元素,$weigeti 是以V开头,符合[A-Z],而且结尾是U,也符合[A-Z]。.无法匹配n // 输出【V-Get.com IS LOVEING YOU】 echo preg_replace('/^[A-Z].*[A-Z]$/s',$weigeti); // 这个用修饰符s,也就是 . 可以匹配 n 了,所以整句匹配,输出空 // 输出【】 echo preg_replace('/^[A-Z].*[A-Z]$/m',$weigeti); // 这里使用了修饰符,将n作为多行独立匹配。也就等价于: /* $preg_m=preg_replace('/^[A-Z].*[A-Z]$/m',$weigeti); $p='/^[A-Z].*[A-Z]$/'; $a=preg_replace($p,'V-Get.com'); $b=preg_replace($p,'IS'); $c=preg_replace($p,'LOVING'); $d=preg_replace($p,'YOU'); $preg_m === $a.$b.$c.$d; */ // 输出【V-Get.com】 ?> 以后您在使用PHP 抓取某个网站内容,并用正则批量替换的时候,总无法避免忽略获取的内容包含换行符,所以在使用正则替换的时候一定要注意。 PHP 正则匹配执行函数PHP 正则替换可以使用一个修饰符e,代表 eval() 来执行匹配后的内容某个函数。 <?php $weigeti='W3CSchool 在线教程网址:http://E.V-Get.com/w3c/ ,你V-Get!了吗?'; // 将上面网址转为小写 echo preg_replace('/(http:[/w.-]+/)/e','strtolower("$1")',$weigeti); // 使用修饰符e之后,就可以对匹配的网址执行PHP 函数 strtolower() 了 // 输出 【W3CSchool 在线教程网址:http://e.v-get.com/w3c/ ,你V-Get!了吗?】 ?> 根据上面代码,尽管匹配后的函数 strtolower() 在引号内,但是依旧会被eval()执行。 正则替换匹配变量向后引用如果您熟悉Javascript,一定对$1 $2 $3 …… 等向后引用比较熟悉,而在 PHP 中这些也可以被当作向后引用参数。而在PHP中,还可以使用 1 1 来表示向后引用。 向后引用的概念就是匹配一个大片段,这个正则表达式内部又被用括号切割成若干小匹配元素,那么每个匹配元素就被按照小括号序列用向后引用代替。 <?php $weigeti='W3CSchool 在线教程网址:http://e.v-get.com/w3c/ ,你V-Get!了吗?'; echo preg_replace('/.+(http:[w-/.]+/)[^w-!]+([w-!]+).+/','$1',$weigeti); echo preg_replace('/.+(http:[w-/.]+/)[^w-!]+([w-!]+).+/','1','1',$weigeti); // 上面三个都是输出 【http://e.v-get.com/w3c/】 echo preg_replace('/^(.+)网址:(http:[w-/.]+/)[^w-!]+([w-!]+).+$/','栏目:$1<br>网址:$2<br>商标:$3',$weigeti); /* 栏目:W3CSchool 在线教程 网址:http://e.v-get.com/w3c/ 商标:V-Get! */ // 括号中括号,外面括号先计数 echo preg_replace('/^((.+)网址:(http:[w-/.]+/)[^w-!]+([w-!]+).+)$/','原文:$1<br>栏目:$2<br>网址:$3<br>商标:$4',$weigeti); /* 原文:W3CSchool 在线教程网址:http://e.v-get.com/w3c/ ,你V-Get!了吗? 栏目:W3CSchool 在线教程 网址:http://e.v-get.com/w3c/ 商标:V-Get! */ ?> 附: PHP 正则表达式
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |