Perl XML :: DOM解析器用法

时间:2010-11-14 23:16:03

标签: xml perl dom xml-parsing

我正在尝试获取此XML文件第五行中的错误数量:

<summary>
  <result usecase="CRUD" target="AppHost">
    <testcase size="1" cvus="1">
      <sequence tps="0.25" totaltx="1" name="CRUD" min="3515" max="3515" errors="0" average="3515.0">
        <node tps="0.25" totaltx="1" name="localhost" min="3515" max="3515" errors="0" average="3515.0">
            […]
        </node>
      </sequence>
    </testcase>
  </result>
</summary>

使用XML :: DOM :: Parser和此代码:

my $parser = new XML::DOM::Parser;
my $doc = $parser->parsefile($file);
my $root = $doc->getDocumentElement();

foreach my $child ($root->getChildNodes) {
    print $child->getNodeName();
    print "\n";
}

但不是只打印“结果”,我得到了这个:

#text
result
#text

要获得第五行中“节点”节点的参数,我想使用getFirstChild方法,但我不能,因为它查找“#text”的子节点。

这个#text对象是什么?我该怎么办才能到达第五个节点?

谢谢,

凯文

1 个答案:

答案 0 :(得分:4)

尝试:

#!/usr/bin/perl

use XML::DOM;
use XML::Parser;

$file = "test.xml";

my $parser = new XML::DOM::Parser;
my $doc = $parser->parsefile($file);

print $doc->getElementsByTagName('node')->item(0)->getAttributeNode('errors')->getFirstChild->getNodeValue;
print "\n";