Как я могу отсортировать узлы XML по нескольким атрибутам, используя SimpleDom sortedxpath?
Я использую библиотеку 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' в соответствии со значениями атрибутов 'year', 'month' и 'day' узла 'entry_date', причем все в обратном порядке (самые последние сверху). Итак, в приведенном выше примере я бы хотел, чтобы окончательный порядок был:
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);
}
Любая помощь с удовольствием оценена. Спасибо!
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
}
Я надеюсь, что это может помочь другим. Спасибо за прочтение.