是否有人愿意帮助我弄清楚如何使用特许经营id从第二个XML页面检索特许经营名称?
我正在处理两个不同的页面。第一页会给我一个特许经营id的列表。我希望能够通过使用第一页的特许经营id从第二个XML页面获得特许经营名称。
如果您需要更多的信息,请告诉我,以便我能帮助您。
我正在寻找PHP的答案。
PHP:解析第一个XML页面
$url = "XMLPAGEURL";
$xml = simplexml_load_file($url);
foreach ($xml->franchise as $franchise) {
echo ''.$franchise[id].'';
}
第二个XML页
<league id="1"/>
<franchises count="5">
<franchise name="A" id="0001"/>
<franchise name="B" id="0002"/>
<franchise name="C" id="0003"/>
<franchise name="D" id="0004"/>
<franchise name="E" id="0005"/>
</franchises>
</league>
您不应该嵌套两组数据的循环,因为在第二组数据中只有一个匹配,即第一个数据的当前id。分别执行它们并合并数据是最好的解决方案
<?php
$data=array();
$url1 = "http://football99.myfantasyleague.com/2007/export?TYPE=standings&L=46184&XML=1";
$xml = simplexml_load_file($url1);
foreach ($xml->franchise as $franchise)
{
$id=(string) $franchise->attributes()->id;
$data[$id]['id']=$id;
foreach($franchise as $key=>$value)
{
$data[$id][$key]=(string) $value;
}
}
$url2 = "http://football99.myfantasyleague.com/2007/export?TYPE=league&L=46184&XML=1";
$xml_second = simplexml_load_file($url2);
foreach($xml_second->franchises->franchise as $franchise_sec)
{
//var_dump($franchise_sec);
$id=(string) $franchise_sec->attributes()->id;
foreach($franchise_sec->attributes() as $key=>$value)
{
$data[$id][$key]=(string) $value;
}
}
print_r($data);
将id
放在第一个循环的数据中,将name
放在第二个循环中,使用id作为两者的索引(因为这是公共元素)
我也尝试添加一些其他数据
当测试证明需要更改代码时更新
生成的输出为:-
Array
(
[0009] => Array
(
[id] => 0009
[h2hw] => 12
[name] => Hindenberg
[logo] => http://www99.myfantasyleague.com/fflnet2005/helmets/h-0051.gif
)
[0004] => Array
(
[id] => 0004
[h2hw] => 9
[name] => Skins
[logo] => http://www99.myfantasyleague.com/fflnet2005/helmets/h-0837.gif
)
[0010] => Array
(
[id] => 0010
[h2hw] => 9
[name] => Marooned
[logo] => http://www99.myfantasyleague.com/fflnet2005/helmets/h-0841.gif
)
[0003] => Array
(
[id] => 0003
[h2hw] => 7
[name] => Elf Boys
[logo] => http://www99.myfantasyleague.com/fflnet2005/helmets/h-0703.gif
)
[0007] => Array
(
[id] => 0007
[h2hw] => 7
[name] => Juggernaut
[logo] => http://www99.myfantasyleague.com/fflnet2005/helmets/h-0689.gif
)
[0006] => Array
(
[id] => 0006
[h2hw] => 7
[name] => Knights
[logo] => http://www99.myfantasyleague.com/fflnet2005/helmets/h-0708.gif
)
[0002] => Array
(
[id] => 0002
[h2hw] => 7
[name] => Dr. Death
[logo] => http://www99.myfantasyleague.com/fflnet2005/helmets/h-0829.gif
)
[0005] => Array
(
[id] => 0005
[h2hw] => 6
[name] => Busted Season
[logo] => http://www99.myfantasyleague.com/fflnet2005/helmets/h-0842.gif
)
[0001] => Array
(
[id] => 0001
[h2hw] => 4
[name] => Deep Divot
[logo] => http://www99.myfantasyleague.com/fflnet2005/helmets/h-0826.gif
)
[0008] => Array
(
[id] => 0008
[h2hw] => 3
[name] => Last Place
[logo] => http://www99.myfantasyleague.com/fflnet2005/helmets/h-0827.gif
)
)
您可以按照以下方式检索数据:-
while(list($key,$franchise)=each($data))
{
echo $franchise['id'].': '.$franchise['name'].' <img src="'.$franchise['logo'].'"/><br />';
}