这是我在Stack Overflow上的第一篇文章,我不得不说我发现这个网站是一个答案的金矿! 所以,第一篇文章有点像noobish-关于这个主题有很多答案,但似乎不适合我的确切问题。使用命名空间访问XML的代码很有效,而且非常简洁,所以可能会帮助任何人试图找出这个... ...
我有一个我正在阅读的XML文件:
<?xml version='1.0'?>
<epp xmlns="urn:ietf:params:xml:ns:epp-1.0" xmlns:domain="urn:ietf:params:xml:ns:domain-1.0" xmlns:ext-domain="http://www.heartinternet.co.uk/whapi/ext-domain-2.4">
<response>
<result code='1000'>
<msg>Command completed successfully</msg>
</result>
<resData>
<domain:chkData>
<domain:cd>
<domain:name avail="1">foo.com</domain:name>
</domain:cd>
<domain:cd>
<domain:name avail="0">foo.net</domain:name>
<domain:reason>registered</domain:reason>
</domain:cd>
<domain:cd>
<domain:name avail="0">foo.org</domain:name>
<domain:reason>unknown</domain:reason>
</domain:cd>
<domain:cd>
<domain:name avail="0">foo.plumbing</domain:name>
<domain:reason>c:category7</domain:reason>
</domain:cd>
<domain:cd>
<domain:name avail="1">foo.uk</domain:name>
<domain:reason>qualified</domain:reason>
</domain:cd>
</domain:chkData>
</resData>
<extension>
<ext-domain:categorisedChkData>
<ext-domain:cd>
<ext-domain:name price="1050.37">foo.plumbing</ext-domain:name>
</ext-domain:cd>
</ext-domain:categorisedChkData>
</extension>
<trID>
<clTRID>6f2d7447511677c62631e4bdb9563172</clTRID>
<svTRID>test-da76f89aacec9861b89bf093fc120566</svTRID>
</trID>
</response>
</epp>
我希望能够访问域名的孩子:cd。 请参阅以下代码中的评论
$xml = simplexml_load_string($return_xml, NULL, NULL, "urn:ietf:params:xml:ns:epp-1.0");
$xml->registerXPathNamespace('domain', 'urn:ietf:params:xml:ns:domain-1.0');
$xml->registerXPathNamespace('ext-domain', 'http://www.heartinternet.co.uk/whapi/ext-domain-2.4');
// I can list out the domain:name elements and attributes nicely.
foreach ($xml->xpath('//domain:name') as $domain){
echo '<p>Domain: '.$domain.'<br/>'; // Works
echo 'avail-code: '.$domain['avail'].'<br/>'; // Works
echo '</p>';
}
// And I can list out the domain:reason elements afterwards.
foreach ($xml->xpath('//domain:reason') as $reason){
echo '<p>Reason: '.$reason.'<br/>'; // Works
echo '</p>';
}
// But what I want, is to be able to get to them both from the same node in the order I need them.
// A little like this, so that I can form some content.
$res = $xml->xpath('//domain:cd');
foreach ($res->children() as $node){
echo '<p>Name: '.$node['domain:name'].'<br/>'; // this is wrong, mind.
echo 'Reason: '.$node['domain:reason'].'<br/>'; // this is wrong, mind.
echo '</p>';
}
要运行单独的xpath查询以获取每一位数据似乎有点浪费和繁琐,我应该能够访问节点的子节点(域:名称,域:原因),但解决方案有点难以捉摸,尤其是名称空间的额外复杂性。
谢谢大家。 :)
答案 0 :(得分:2)
谢谢,Ghost。
我设法提出以下内容虽然可以让我以随机顺序而不是连续顺序提取数据。
$res = $xml->xpath('//domain:cd');
foreach ($res as $node){
$namespaces = $node->getNameSpaces(true);
$cd = $node->children($namespaces['domain']);
echo '<p>'. $cd->name.'<br/>';
echo $cd->reason.'</p>';
}
呸,就在你在论坛上发布问题之后,它总是来找你!