- 论坛徽章:
- 0
|
<JOBS>
<JOB id="1" cmd="a.sh" step="hour"></JOB>
<JOB id="2" cmd="b.sh" step="day"></JOB>
<JOB id="3" cmd="c.sh" step="day"></JOB>
<JOB id="4" cmd="d.sh" step="day"></JOB>
</JOBS>
解析出的结果是:
$VAR1 = {
'JOB' => {
'4' => {
'step' => 'day',
'cmd' => 'd.sh'
},
'1' => {
'step' => 'hour',
'cmd' => 'a.sh'
},
'3' => {
'step' => 'day',
'cmd' => 'c.sh'
},
'2' => {
'step' => 'day',
'cmd' => 'b.sh'
}
}
};
现将xml文件只保留1个JOB。
<JOBS>
<JOB id="1" cmd="a.sh" step="hour"></JOB>
</JOBS>
用同一个PERL再进行解析,结果如下:
$VAR1 = {
'JOB' => {
'step' => 'hour',
'cmd' => 'a.sh',
'id' => '1'
}
};
问题如下:当XML只有1个JOB时,解析出来的结果和多个JOB时不同(得到的Hash数据结构不同),没法对它们统一处理。请问处理能够使这两种情况得到的Hash数据结构相同?
perl程序如下:
#!/usr/local/bin/perl
use XML::Simple;
use Data:: Dumper;
my $simple = XML::Simple->new (ForceArray => 1);
my $cfgfile= $simple->XMLin("test.xml" );
print Dumper($cfgfile);
[ 本帖最后由 卡龙1980 于 2008-7-21 16:04 编辑 ] |
|