2017-08-14 97 views
0

这里是我试图解析属性值对应于节点公司提取样本数据:CID,名称,符号,价值在公司节点的所有公司节点XML解析使用XML ::的libxml

<?xml version="1.0" encoding="UTF-8"?> 
<StockRecords xmlns="http://url1" 
       xmlns:ref="http://url2" 
       xmlns:xsi="http://url3"> 
    <Companies> 
    <Company> 
     <CID>123</CID> 
     <Name>Google</Name> 
     <Symbol>GOOG</Symbol> 
     <Value>1234</Value> 
    </Company> 
    </Companies> 
</StockRecords> 

以下是我试过的两个变体。 变体1

use XML::LibXML; 

my $filename = "test.xml"; 
my $dom = XML::LibXML->load_xml(location => $filename); 

foreach my $sample ($dom->findnodes('/Companies/Company')) { 

    print Dumper($sample); 
    last; 
} 

变体2:由于有参与它,XPathContext被指定的命名空间。

use XML::LibXML; 

my $filename = "test.xml"; 
my $parser = XML::LibXML->new(); 
my $xmldoc = $parser->parse_file($filename); 

my $root = $xmldoc->getDocumentElement; 

my @l = $root->getElementsByTagName('StockRecords'); 

my $xc = XML::LibXML::XPathContext->new($root); 

$xc->registerNs("ns1", "http://url1"); 
$xc->registerNs("ref", "http://url2"); 
$xc->registerNs("xsi", "http://url3"); 

我无法提取节点的任何属性的数据。我看了其他答案,LibXML文档仍然存在一些缺失。请帮我指点一下。谢谢

回答

1
use strict; 
use warnings; 
use feature qw(say); 

use XML::LibXML    qw(); 
use XML::LibXML::XPathContext qw(); 

my $doc = XML::LibXML->load_xml(location => $ARGV[0]); 

my $xpc = XML::LibXML::XPathContext->new(); 
$xpc->registerNs(ns1 => "http://url1"); 

for my $company_node ($xpc->findnodes("/ns1:StockRecords/ns1:Companies/ns1:Company", $doc)) { 
    say $xpc->findvalue("ns1:CID", $company_node); 
    say $xpc->findvalue("ns1:Name", $company_node); 
} 
+0

这正是我在找的,谢谢。 有一个在源 代替 这将是, <符号类型= “NASDAQ”>一个小的修改GOOG 如何解析从XML节点的 'type' 属性? – madmatrix