所以我有这个XML文件,我只需要列出每个地区特定的网站。
<xls2cli>
<Region id="Region1">
<site>Site1</site>
<site>Site2</site>
</Region>
<Region id="Region2">
<site>Site3</site>
<site>Site4</site>
<site>Site5</site>
<site>Site6</site>
</Region>
<Region id="Region3">
<site>Site 7</site>
</Region>
</xls2cli>
我可以列出所有的网站,但无论我尝试什么,我都无法让它只列出每个地区特定的网站。我想用一种可以拥有Region['Region1']->site
这样的东西的方式来做,但显然这不起作用。有没有办法在不使用索引的情况下做到这一点?
foreach ($xls2cli->Region as $Region){
echo $Region[id]."<br>";
foreach ($Region->site as $site){
echo $site."<br>"; } }
id
有什么特别之处,它只是数据的一部分。最简单的方法只是在现有循环中使用一个无聊的旧if
语句:
foreach ($xls2cli->Region as $Region){
if( $Region['id'] == 'Region1' ) {
echo $Region['id']."<br>";
foreach ($Region->site as $site){
echo $site."<br>";
}
}
}
您还可以使用xpath()
方法,该方法可以根据XML:的内容进行查询
foreach ( $xls2cli->xpath('./Region[@id="Region1"]') as $Region ) {
echo $Region['id']."<br>";
foreach ($Region->site as $site){
echo $site."<br>";
}
}