我不熟悉php(刚刚开始学习),我遇到了一个问题: 我在服务器上有一个xml文件(从前夕...但谁在乎)我管理它来“读取”这个文件。它有这样的结构:
<result>
<rowset>
<row name="abc" id="def" ...>
<row name="abc" id="def" ...>
<row name="abc" id="def" ...>
...
</rowset>
</result>
在搜索某些网页时,我找到了一种方法来回显所有行的所有属性。 这是我的代码:
<?php
$url = "http://api.eveonline.com/eve/AllianceList.xml.aspx?version=1";
$xml = simplexml_load_file($url);
$nrOfRows = $xml->result[0]->rowset[0]->count();
$n = 0;
for ($n = 0; $n <= $nrOfRows; $n++) {
foreach($xml->result[0]->rowset[0]->row[$n]->attributes() as $a => $b) {
echo $a, " = ", $b, "<br>";
}
}
?>
结果我得到:
name = abc
id = def
...
name = abc
id = def
...
这看起来不错,但这不是我想要的。 我只需要所有行的特殊属性。例如,我想要所有行的所有名称作为结果。
感谢您的帮助。 沙利叶
答案 0 :(得分:0)
以下是使用DOMDocument和DOMXpath类构建的示例
$xml = <<< LOL
<result>
<rowset>
<row name="abc" id="def" lang="pt">Olá</row>
<row name="abc" id="def" lang="en">Hello</row>
<row name="abc" id="def" lang="fr">Bonjour</row>
</rowset>
</result>
LOL;
$dom = new DOMDocument();
libxml_use_internal_errors(true);
$dom->loadXML($xml);
$xpath = new DOMXpath($dom);
foreach ($xpath->query("//row") as $row){
echo $row->getAttribute('name');
echo $row->getAttribute('id');
echo $row->getAttribute('lang');
echo $row->textContent;
}
以上示例将获取name
,id
,lang
属性以及每个行元素的文本text
。
如果您需要按id
或class
过滤行,请使用;
$xpath->query("//row[@class='someClass']")
$xpath->query("//row[@id='someId']")
答案 1 :(得分:0)
您可以使用数组语法访问单个属性:
echo $xml->result[0]->rowset[0]->row[$n]['name'];
将输出:
Goonswarm Federation
Pandemic Horde
Test Alliance Please Ignore
(...)
另请注意,您可以通过以下方式简化代码:
foreach( $xml->result[0]->rowset[0]->row as $row )
{
echo $row['name'] . '<br>';
}