繁体   English   中英

正则表达式匹配HTML <p> 使用PHP标记

[英]Regular Expression to Match HTML <p> tag using PHP

我有这样的内容

<p>some content, paragraph 1</p>
<p>some content, paragraph 2</p>
<p>some content, paragraph 3</p>

我想返回第一段即

<p>some content, paragraph 1</p>

任何人都可以帮助我使用正则表达式代码吗?
'<p>(.*.)</p>'似乎不起作用

你可以这样做:

if (preg_match('%(<p[^>]*>.*?</p>)%i', $subject, $regs)) {
    $result = $regs[1];
} else {
    $result = "";
}

你根据常规表达式测试你的字符串,如果有一些匹配,你得到第一个,只有第一个,如果没有,$ result将是一个空字符串。

如果你需要获得超过第一个结果,你可以迭代$ regs数组。 而且你需要找到任何其他标签更改常规expresión来加工它,例如找到你使用的IMAGE标签:

(<img[^>]*>.*?</img>)

编辑:如果你是逐行处理(只有你正在寻找的标签),你可以在表达式周围放置^ ... $以匹配整行,如下所示:

if (preg_match('%^(<p[^>]*>.*?</p>)$%im', $subject, $regs)) {
    $result = $regs[1];
} else {
    $result = "";
}

HTH,问候。

防止包含<pre>标签,可以使用:

if (preg_match('/(<p(>|\s+[^>]*>).*?<\/p>)/i', $subject, $regs)) {
    $result = $regs[1];
} else {
    $result = "";
}
  if (preg_match("/\b1\b/i", "some content, paragraph 1")) {
    echo "A match was found.";
} else {
    echo "A match was not found.";
}

其中1是匹配的术语......

这有什么帮助吗?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM