次のような XML データがあります。
私がやりたいことは、次の構造から発行年を単純に抽出することです。
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<pre>
<PubmedArticle>
<MedlineCitation Owner="NLM" Status="In-Data-Review">
<PMID Version="1">23853691</PMID>
<DateCreated>
<Year>2013</Year>
<Month>07</Month>
<Day>15</Day>
</DateCreated>
<Article PubModel="Electronic-Print">
<Journal>
<ISSN IssnType="Electronic">1932-6203</ISSN>
<JournalIssue CitedMedium="Internet">
<Volume>8</Volume>
<Issue>5</Issue>
<PubDate>
<Year>2013</Year>
</PubDate>
...
</pre>
しかし、私の次のコード Perl が年「2013」にアクセスできなかったのはなぜですか?
use strict;
use Data::Dumper;
use XML::LibXML 1.70;
my $parser = XML::LibXML->new();
my $xmlfilename = "myfile.xml";
# obtained from http://dpaste.com/1307466/plain/
my $doc = $parser->parse_file( $xmlfilename );
foreach my $art ( $doc->findnodes('/PubmedArticle/MedlineCitation/Article/Journal/JournalIssue/PubDate') ) {
my ($year) = $art->findnodes('./Year');
print Dumper $year->to_literal ;
}
それを行う正しい方法は何ですか?