怎么用正则匹配带多个属性的html标签
标签各式各样,毫无规律,主要还是属性的顺序不清楚
像这种但是属性顺序不同就有好几种,而且还有分别得到 id href class三种属性值,存到1 2 3中(我用的是preg_replace, 因为要将整个标签替换指定格式)
想了好久不知道这个正则怎么写 望高人帮帮忙
我也想过用 ]*)>匹配到后处理属性,再用str_replace替换回去,但这样重复搜索可能会导致资源开销过大吧 还有什么办法可以实现上面的要求呢?高人帮忙啊
------解决方案--------------------
推荐你学习一下PHPquery的用法,从此采集不需要再用正则
------解决方案--------------------
本帖最后由 xuzuning 于 2014-02-27 09:09:12 编辑
$s =<<< TXT<br /><a id="home" href="/Home/index" class="btn"><br /><a href="/Home/index" id="home" class="class"><br /><a class="btn" href="/home" id="home"><br />TXT;<br /><br />echo preg_replace_callback('/<a\s(.+)>/i', 'foo', $s);<br /><br />function foo($r) {<br /> preg_match_all('/(\w+)="(.+?)"/', $r[0], $t);<br /> $t = array_combine($t[1], $t[2]);<br /> ksort($t);<br /> $s = '';<br /> foreach($t as $k=>$v) $s .= " $k='$v'";<br /> return "<a$s>";<br />}
登录后复制