微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 如何在XPath中仅返回第一个匹配结果?

我尝试使用XPath string-after来获取Property ID之后的数据:但结果不是我想要的.它显示了与Property ID匹配的所有结果.我只想要P-000324.这是我的代码

<?PHP
$getURL = file_get_contents('http://realestate.com.kh/residential-for-rent-in-phnom-penh-daun-penh-phsar-chas-2-beds-apartment-1001192296/');
$dom = new DOMDocument();
@$dom->loadHTML($getURL);
$xpath = new DOMXPath($dom);

echo $xpath->evaluate("normalize-space(substring-after(., 'Property ID:'))");

那么我怎样才能让它只得到一个一个结果呢?

解决方法:

您可以更改XPath表达式,以便仅在第一次出现包含Property ID的p后选择字符串:使用位置索引([1]).

例如,以下XPath表达式将仅选择直接包含字符串’Property ID:’的第一个段落:

(//p[contains(text(),'Property ID:')])[1]

将此与您的请求放在一起,只返回“Property ID:”后面的字符串,但除了P-000324字符串之外没有任何内容

echo $xpath->evaluate("normalize-space(substring-before(substring-after((//p[contains(text(),'Property ID:')])[1], 'Property ID:'), '–'))");

将按要求回应P-000324.

更新:这解决了最初提供的原始页面的问题,但根据评论,目标似乎更广泛.更健壮的解决方案是仅使用第一个表达式来获取包含“Property ID”的第一个段落的字符串,然后在属性id的正常形式上的标签之后立即执行正则表达式模式匹配,或者围绕属性id的正常形式的分隔符.您将不得不使用托管语言的正则表达式工具,因为XPath 1.0的字符串处理功能非常有限; XPath 2.0更好,包括正则表达式功能.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐