我在一个字符串中有4段文本。每个段落都被<p></p>
包围。
- 我的第一个目标是输出前两段。我的第二个目标是将剩下的段落输出到页面的其他地方。我有时可以处理包含超过4段的字符串。
我已经在网上搜索了所有已经存在的东西。有很多关于只显示第一段的内容,但是我没有发现关于显示第1-2段,然后显示其余段落的内容。有人能帮忙吗?
不确定使用哪个,如果有,substr, strpos等.....?
编辑-感谢您的回答,澄清一下,段落不包含HTML的时刻,但是的,我将需要在每个段落中有HTML的选项。
使用正则表达式
$str = '<p style="color:red;"><b>asd</b>para<img src="afs"/>graph 1</p >
<p>paragraph 2</p>
<p>paragraph 3</p>
<p>paragraph 4</p>
';
// preg_match_all('/<p.*>([^<]+)</ps*>/i',$str,$matches);
//for inside html like a comment sais:
preg_match_all('/<p[^>]*>(.*)</ps*>/i',$str,$matches);
print_r($matches);
打印:
Array
(
[0] => Array
(
[0] => <p style="color:red;"><b>asd</b>para<img src="afs"/>graph 1</p >
[1] => <p>paragraph 2</p>
[2] => <p>paragraph 3</p>
[3] => <p>paragraph 4</p>
)
[1] => Array
(
[0] => <b>asd</b>para<img src="afs"/>graph 1
[1] => paragraph 2
[2] => paragraph 3
[3] => paragraph 4
)
)
使用DOMDocument
初始化:
$dom = new DOMDocument;
$dom->loadHTML($myString);
$p = $dom->getElementsByTagName('p');
如果每个可以包含(或不包含)其他HTML元素,创建一个函数:
function getInner(DOMElement $node) {
$tmp = "";
foreach($node->childNodes as $c) {
$tmp .= $c->ownerDocument->saveXML($c);
}
return $tmp;
}
,然后在需要这样的段落时使用该函数:
$p1 = getInner($p->item(0));
您可以在这里阅读更多关于DOMDocument
的信息