我正在使用SimpleDom库并需要有关sortedxpath函数的帮助。 这是XML
<cal>
<entry entry_id="1">
<entry_date year="1980" month="10" day="12" />
<entry_title>John Bday</entry_title>
</entry>
<entry entry_id="2">
<entry_date year="1980" month="10" day="10" />
<entry_title>Peter Bday</entry_title>
</entry>
<entry entry_id="3">
<entry_date year="1980" month="10" day="16" />
<entry_title>Allan Bday</entry_title>
</entry>
</cal>
我想根据'entry_date'节点的'year','month'和'day'属性的值对所有'entry'节点进行排序,所有这些都以相反的顺序排列(最近的最高点) 。所以在上面的例子中,我希望最终的顺序是:
entry #3
entry #1
entry #2
这是我目前使用的PHP无效(根本没有输出):
$xml = simpledom_load_file("data.xml");
foreach ($xml->sortedXPath('entry', 'entry_date_start[@year]', SORT_DESC) as $i => $item)
{
echo($item);
}
任何帮助都很高兴。谢谢!
答案 0 :(得分:1)
最后通过反复试验找到了正确的语法:
foreach ($xml->sortedXPath('entry', 'entry_date/@year', SORT_DESC, 'entry_date/@month', SORT_DESC, 'entry_date/@day', SORT_DESC) as $i => $item)
{
// do stuff
}
我希望这可以帮助别人。谢谢你的阅读。