您好我正在使用DOM从xml文件中检索数据。下面的代码对于xml文件工作得很好,但我面临的主要问题是它只识别根节点,它不识别子节点。 这是我的代码: -
$dom = new DOMDocument();
$dom->load($url);
$link = $dom->getElementsByTagName($tag_name);
$value = array();
for ($i = 0; $i < $link->length; $i++) {
$childnode['name']=$link->item($i)->nodeName;
$childnode['value']=$link->item($i)->nodeValue;
$value[ $childnode['name']] = $childnode['value'];
// echo $link->item($i)->nodeValue . '<br>';
$k++;
}
这是我显示数据的视图文件
foreach($value as $node=>$value)
{
echo "<b> Node :</b>".$node."<br /><b>Value:</b>".$value."<br /><hr>";
}
这是我的xml文件
<name>John</name>
<place>Australia</place>
<contact>
<phone>8734563485</phone>
<type>Mobile</type>
</contact>
<mail>somedata</mail>
我能够读取父节点i,e名称,地点,联系方式,邮件。但我无法读取子节点i,电话,类型。 任何人都可以帮助我使用代码....
答案 0 :(得分:1)
因为您当然没有遍历子节点。 我会创建一个函数并以递归方式遍历它。
function addNodesToValue($value,$nodelist) {
for ($i = 0; $i < $nodelist->length; $i++) {
$childnode['name']=$nodelist->item($i)->nodeName;
$childnode['value']=$nodelist->item($i)->nodeValue;
$value[ $childnode['name']] = $childnode['value'];
// recursive traverse child nodes
if($nodelist->item($i)->hasChildNodes()){
$value = addNodesToValue($value,$nodelist->item($i)->childNodes);
}
}
return $value;
}
//usage
$value = addNodesToValue($value,$link);
答案 1 :(得分:0)
这个怎么样?
function get_names($node) {
$names = array();
foreach ($node->childNodes as $child) {
if ($child->nodeType == 1) {
$names[] = $child->nodeName;
if ($child->hasChildNodes()) {
$names[] = get_names($child);
}
}
}
return array_filter($names);
}
$xml = '
<root>
<name>John</name>
<place>Australia</place>
<contact>
<phone>8734563485</phone>
<type>Mobile</type>
</contact>
<mail>somedata</mail>
</root>';
$names = get_names( DOMDocument::loadXML($xml)->firstChild );
print_r($names);
输出;
Array ( [0] => name [2] => place [4] => contact [5] => Array ( [0] => phone [2] => type ) [6] => mail )
答案 2 :(得分:0)
解决:
注意,我的XML包含一个任意的“item”节点,因此值得使用您的XML进行测试。这是我的:
<news>
<item>
<date>9/2/2014</date>
<title>Home Depot Breach</title>
<content>NEW YORK (AP) - My store may be the latest retailer</content>
</item>
<item>
<date>8/28/2014</date>
<title>Dairy Queen</title>
<content>Dairy Queen has the best ice cream</content>
</item>
</news>
我有一个列出表格中项目的页面。当您单击其中一个项目时,它会将该项目的ID#发送到PHP脚本中......这是我处理点击的“项目”的方式:
$xml = DOMDocument::load('news.xml');
$id = $_GET['i'];
$date = $xml->getElementsByTagName('date')->item($id)->nodeValue;
$title = $xml->getElementsByTagName('title')->item($id)->nodeValue;
$content = $xml->getElementsByTagName('content')->item($id)->nodeValue;