在下面的 XML 文件中,我尝试打印所有TestItem
节点,但只获取 4outer
个节点。
有人知道,如何打印具有该名称的每个节点,无论它们的位置如何?
数据.xml:
<?xml version="1.0"?>
<Tests>
<TestItem Name="UpdateBootProfile" Result="PASS" />
<TestItem Name="NRB Boot" Result="PASS">
<TestItem Name="Boot Test" Result="PASS">
<TestItem Name="PreparePowerSupply" Result="PASS" />
<TestItem Name="ApplyBatteryVoltage" Result="PASS" />
<TestItem Name="Shelf Mode test" Result="PASS">
</TestItem>
<TestItem Name="ApplyUSBVoltage" Result="PASS" />
<TestItem Name="DetectBoard" Result="PASS" />
<TestItem Name="Device Current Profile" Result="PASS" />
<TestItem Name="Device Connection" Result="PASS">
</TestItem>
</TestItem>
</TestItem>
<TestItem Name="Check device Type" Result="PASS" />
<TestItem Name="Assign BSN and Erase EFS" Result="PASS">
</TestItem>
</Tests>
解析.php:
<?php
$tmp = 'data.xml';
$str = file_get_contents($tmp);
$xml = new SimpleXMLElement($str);
$items = $xml->xpath('TestItem');
while(list( , $test) = each($items)) {
printf("%s %s\n", $test['Name'], $test['Result']);
}
?>
php -f parse.php输出(为什么它只列出 4 个 TestItem?):
UpdateBootProfile PASS
NRB Boot PASS
Check device Type PASS
Assign BSN and Erase EFS PASS
在 CentOS 6.3 命令行上使用 PHP 5.3.5。
更新:
建议//TestItem
适用于我上面的简单测试用例,谢谢。
但是我的真实数据仍然失败(我不能在这里粘贴):
# grep -w TestItem my_real_file_May_2013_09_35_38.xml |wc -l
143
# php -f parse.php |wc -l
86
有没有人有一个想法,会//TestItem
错过一些节点?
更新 2:
实际上它有效!由于一些</TestItem>
结束标签,上面的 grep 突击队计算了更多行 :-)