4

我需要一些关于 xpath 的帮助来从 html 页面中提取价值 $283。

这是我的PHP

$html = file_get_contents("https://test.com/testpage.php");
$html = tidy_repair_string($html);
$doc = new DomDocument();
$doc->loadHtml($html);
$xpath = new DomXPath($doc);

$avg = $xpath->evaluate('string(//*[@id="Average"]/@value)');
echo $avg;

这是HTML

<div class="List">
    <span class="bold">Avg</span> 
    <span id="Average">$283</span>
</div>

提前致谢。

4

1 回答 1

7

试试这个 XPath 表达式:

//div[@class="List"]/span[@id="Average"]

或者简单地说:

//*[@id='Average']

这是一个完整的工作代码:

<?php
$doc = new DOMDocument();
$doc->loadHTMLFile('http://127.0.0.1/test.html');

$xpath = new DOMXpath($doc);

$elements = $xpath->query("//*[@id='Average']");

if (!is_null($elements)) {
    foreach ($elements as $element) {
        $nodes = $element->childNodes;
        foreach ($nodes as $node) {
            echo $node->nodeValue. "\n";
        }
    }
}
?>

只需将 URL 替换为您自己的。

于 2012-06-03T20:50:48.163 回答