[英]Iterating over child nodes in XML file with JavaScript using XPath
[英]Iterating over nodes using XML::LibXML
我正在使用 XML::LibXML(版本:1.70)。
我的 xml 輸入文件如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<Equipment xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<Equipments>
<ECID logicalName="SysNameAlpha" id="0"/>
<ECID logicalName="SysNameBeta" id="1"/>
</Equipments>
</Equipment>
和我的 Perl 腳本:
my $file = 'data.xml';
my $parser = XML::LibXML->new();
my $tree = $parser->parse_file($file);
my $root = $tree->getDocumentElement;
foreach my $camelid ($root->findnodes('Equipments')) {
my $name = $camelid->findvalue('ECID/@logicalName');
my $id = $camelid->findvalue('ECID/@id');
print $name;
print " = ";
print $id;
print ";\n";
}
我得到的 output 是:
SysNameAlphaSysNameBeta = 01;
但我想要這樣的 output :
SysNameAlpha = 0;
SysNameBeta = 1;
我怎樣才能做到這一點?
只有一個Equipments
節點,因此您只能掃描一個$camelid
。 為了補救,您可能會稍微改變一些東西,例如,迭代設備/ECID:
foreach my $camelid ( $root->findnodes('Equipments/ECID') ) {
my $name = $camelid->findvalue('@logicalName');
my $id = $camelid->findvalue('@id');
...
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.