首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用SimpleDom sortedxpath对多个属性上的XML节点进行排序?

如何使用SimpleDom sortedxpath对多个属性上的XML节点进行排序?
EN

Stack Overflow用户
提问于 2010-11-15 07:51:29
回答 1查看 1.5K关注 0票数 1

我正在使用SimpleDom库,需要有关sortedxpath函数的帮助。这是XML

代码语言:javascript
复制
<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‘节点进行排序,所有这些都是以逆序排列的(最新的在顶部)。所以在上面的例子中,我希望最后的顺序是:

代码语言:javascript
复制
entry #3
entry #1
entry #2

下面是我目前使用的PHP,它不工作(根本没有输出):

代码语言:javascript
复制
$xml = simpledom_load_file("data.xml");
foreach ($xml->sortedXPath('entry', 'entry_date_start[@year]', SORT_DESC) as $i => $item)
{
   echo($item);
}

任何帮助都会很高兴的感谢。谢谢!

EN

回答 1

Stack Overflow用户

发布于 2010-11-16 11:02:29

经过反复试验,最终找到了正确的语法:

代码语言:javascript
复制
foreach ($xml->sortedXPath('entry', 'entry_date/@year', SORT_DESC, 'entry_date/@month', SORT_DESC, 'entry_date/@day', SORT_DESC) as $i => $item)
{
   // do stuff
}

我希望这能帮助到其他人。感谢您的阅读。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4180450

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档