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