正则表达式中的零宽断言

群友问如何一定用正则取到
index.php?js=jquery&css=css3&html=xhtml
类似url中的jquery,css3,xhtml

解答
<?php
	preg_match_all("/(?<=\=)(.*?)(?=(&|$))/", "index.php?index.php?js=jquery&css=css3&html=xhtml", $matches);
	var_dump($matches);


输出
array(3) {
  [0]=>
  array(3) {
    [0]=>
    string(6) "jquery"
    [1]=>
    string(4) "css3"
    [2]=>
    string(5) "xhtml"
  }
  [1]=>
  array(3) {
    [0]=>
    string(6) "jquery"
    [1]=>
    string(4) "css3"
    [2]=>
    string(5) "xhtml"
  }
  [2]=>
  array(3) {
    [0]=>
    string(1) "&"
    [1]=>
    string(1) "&"
    [2]=>
    string(0) ""
  }
}


说明
正则中的零宽断言
按一定条件匹配却不包含进来
(?<=\=)  以=为开始匹配,但不包含
(?=(&|$))以&或行尾为结尾匹配,但不包含

资料
引用
零宽断言

接下来的四个用于查找在某些内容(但并不包括这些内容)之前或之后的东西,也就是说它们像\b,^,$那样用于指定一个位置,这个位置应该满足一定的条件(断言),因此它们也被称为零宽断言。最好还是拿例子来说明吧:

(?=exp)也叫零宽度正预测先行断言,它断言自身出现的位置的后面能匹配表达式exp。比如\b\w+(?=ing\b),匹配以ing结尾的单词的前面部分(除了ing以外的部分),如查找I'm singing while you're dancing.时,它会匹配sing和danc。

(?<=exp)也叫零宽度正回顾后发断言,它断言自身出现的位置的前面能匹配表达式exp。比如(?<=\bre)\w+\b会匹配以re开头的单词的后半部分(除了re以外的部分),例如在查找reading a book时,它匹配ading。

假如你想要给一个很长的数字中每三位间加一个逗号(当然是从右边加起了),你可以这样查找需要在前面和里面添加逗号的部分:((?<=\d)\d{3})*\b,用它对1234567890进行查找时结果是234567890。

下面这个例子同时使用了这两种断言:(?<=\s)\d+(?=\s)匹配以空白符间隔的数字(再次强调,不包括这些空白符)。

http://www.cssrain.cn/demo/zhengze.htm

你可能感兴趣的:(jquery,PHP,正则表达式,XHTML,css)