嗨我有像这样的xml数据
<university>
<name>svu</name>
<location>ravru</location>
<branch>
<electronics>
<Section>
<student name="xxx" number="12">
<sem semister="1"subjects="7" rank="1"/>
<sem semister="2"subjects="4" rank="1"/>
<student>
<student name="xxx" number="15">
<sem semister="1"subjects="7" rank="10"/>
<sem semister="2"subjects="4" rank="1"/>
<student>
<student name="xxx" number="16">
<sem semister="1"subjects="7" rank="2"/>
<sem semister="2"subjects="4" rank="2"/>
<student>
</section>
</electronics>
</branch>
</university>
<university>
<name>sku</name>
<location>ANTP</location>
<branch>
<computers>
<Section>
<student name="xxx" number="12">
<sem semister="1"subjects="7" rank="no"/>
<sem semister="2"subjects="4" rank="no"/>
<student>
<student name="xxx" number="15">
<sem semister="1"subjects="7" rank="10"/>
<sem semister="2"subjects="4" rank="1"/>
<student>
<student name="xxx" number="16">
<sem semister="1"subjects="7" rank="20"/>
<sem semister="2"subjects="4" rank="21"/>
<student>
</section>
</electronics>
</branch>
</university>
我使用了XML :: Simple,我生成了哈希结构化数据并存储在变量中。我使用template :: toolkit生成pdffile(使用pdflatex)。我的XML :: simple输出是这样的
$var1={
university=>{
'name'=>'svu',
'location'=>'ravru',
'branch'=>{
'electronics'=>{
'section'=>[
{
'name'=>'xxx',
'number'=>'12',
'sem'=>[
{
'semister'=>'1',
'subjects'=>'7',
'rank'=>'1'
},
{
'semister'=>'2',
'subjects'=>'4',
'rank'=>'1'
}
]
},
{
'name'=>'xxx',
'number'=>'15',
'sem'=>[
{
'semister'=>'1',
'subjects'=>'7',
'rank'=>'10'
},
{
'semister'=>'1',
'subjects'=>'7',
'rank'=>'1'
}
]
},
{
'name'=>'xxx',
'number'=>'16',
'sem'=>[
{
'semister'=>'1',
'subjects'=>'7',
'rank'=>'2'
},
{
'semister'=>'2',
'subjects'=>'4',
'rank'=>'2'
}
]
}
}
]
}
};
像这样我有15所大学,还有一些学生只有两三个学生,有些学生有10个,在学生中,有些学生只有一个学生,有些学期有两个学期。我这样写的模板
my $template = Template->new();
my $filename = 'output.tex';
$template->process(\*DATA, $data, $filename)
|| die "Template process failed: ", $template->error(), "\n";
system( "pdflatex $filename" );
__DATA__
\documentclass[a4paper,leqno,twoside]{article}
\begin{document}
[% FOREACH st = university %]
[%+ st.name +%]
[%+ st.location +%]
[% FOREACH section = st.branch.electronics.section %]
branch student: [%+ section.name +%]
[%+ section.number +%]
[% FOREACH sem = section.sem %]
[%+ sem.semister +%]
[%+ sem.subjects +%]
[%+ sem.rank +%]
[% END %]
[% END %]
[% END %]
/end{document}
像这样它给出了输出,但是我的问题是它太冗长而且我上面说过一些部分有两个学生,有些部分有两个以上。例如,第一部分包含1名学生,第二部分包含10名学生。但是在pdf的第一部分还印刷了10名学生,只有第一名学生的信息仍然是空的。我怎样才能消除这个问题。
如果您不理解我的问题,我怎么能使用比我写的更短的代码来获取数据。有没有其他方法来获得分支元素所有更简单的使用for循环的分支元素或任何简单的代码。因为如果一些部分有60个学生所以它在每个部分打印6o。
答案 0 :(得分:1)
上面粘贴的内容在语法上似乎不正确。你在jocking :)?
无论如何,请阅读Introduction of the manual .... 将结构传递给TT存储后,您可以访问其元素,例如:
[% var1.STC.0.gym.hyd.com (AND SO ON) %]
你应该避免太深的结构。
答案 1 :(得分:1)
我认为你在这些部分只需要另一个FOREACH
,如下所示:
[%+ university.name +%]
[%+ university.location +%]
[% FOREACH section = university.branch.electronics.section %]
branch student: [%+ section.name +%]
[%+ section.number +%]
[% FOREACH sem = section.sem %]
[%+ sem.semister +%]
[%+ sem.subjects +%]
[%+ sem.rank +%]
[% END %]
[% END %]
您可能需要添加custom filter,custom vmethod或plugin,以确保所有字符串都已正确转义以便在LaTeX中使用。如果您不关心如何处理换行符,请使用[% ... %]
,[%+ ... +%]
版本会保留前导空格和尾随空格。