我一直在尝试使用DOMXPath编写PHP脚本来解析XML文档;但似乎我遗漏了一些东西,因为我的XPath查询都没有返回任何内容。所以我试图淡化我的脚本来尝试解析一个非常基本的XML文档,而这也不起作用。我将此脚本基于this XPath example。
<?php
$xml = '<?xml version="1.0" encoding="ISO-8859-1"?>';
$xml .= '<bookstore>';
$xml .= '<book category="COOKING">';
$xml .= '<title lang="en">Everyday Italian</title>';
$xml .= '<author>Giada De Laurentiis</author>';
$xml .= '<year>2005</year>';
$xml .= '<price>30.00</price>';
$xml .= '</book>';
$xml .= '</bookstore>';
$dom = new DOMDocument('1.0');
$dom->loadXML($xml);
$xpath = new DOMXPath($dom);
$result = $xpath->query('/bookstore/book[1]/title');
var_dump($result);
?>
问题是$ result 总是的var_dump会返回如下内容:
object(DOMNodeList)#4 (0) { }
...表明它一无所获。
答案 0 :(得分:5)
在这种情况下,var_dump()的输出具有误导性。 尝试
foreach($result as $e) {
echo $e->nodeValue;
}
或
echo $result->length;
代替。
e.g。使用你的代码(直到$ result = $ xpath ....)+
echo phpversion(), "\n";
var_dump($result);
echo $result->length, "\n";
foreach($result as $e) {
echo $e->nodeValue;
}
输出
5.3.1
object(DOMNodeList)#4 (0) {
}
1
Everyday Italian
答案 1 :(得分:0)
我在根节点中指定xmlns =“http://www.w3.org/2005/Atom”的文档时遇到了困难。拿出来,xpath工作。