Dav*_*lis 20 php parsing preg-match
您好我想在PHP中使用preg_match来解析html文档中的"Desired text"
<p class="review"> Desired text </p>
Run Code Online (Sandbox Code Playgroud)
通常我会使用simple_html_dom这样的东西,但在这种情况下它不能使用(上面的元素没有出现在每个所需的div标签中,所以我被迫使用这种方法来准确跟踪它何时没有出现和然后相应地从simple_html_dom调整我的数组).
无论如何,这将解决我的问题.
非常感谢.
ser*_*erg 68
preg_match("'<p class=\"review\">(.*?)</p>'si", $source, $match);
if($match) echo "result=".$match[1];
Run Code Online (Sandbox Code Playgroud)
And*_*y N 11
如果你想返回多个匹配,那么需要使用preg_match_all().然后循环遍历第二个结果组($ match [1])以获取标记之间的内容.
$source = "<p class=\"review\"> Desired text1 </p>".
"<p class=\"review\"> Desired text2 </p>".
"<p class=\"review\"> Desired text3 </p>";
preg_match_all("'<p class=\"review\">(.*?)</p>'si", $source, $match);
foreach($match[1] as $val)
{
echo $val."<br>";
}
Outputs:
Desired text1
Desired text2
Desired text3
Run Code Online (Sandbox Code Playgroud)
如果您匹配的字符串有多行并且是:
<p class="review"> Desired text1 </p>
<p class="review"> Desired text2 </p>
<p class="review"> Desired text3 </p>
Run Code Online (Sandbox Code Playgroud)
该模式将匹配一次,匹配将是字符串中的所有内容.
我认为更好的模式是:
"'<p class=\"review\">([^<]*)</p>'si"
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
90463 次 |
最近记录: |