我在这里阅读了很多帖子,但我仍然无法弄清楚如何使用simplexml函数对我正在从OPML文件中读取的数据进行排序。我意识到这有点重复,但我显然太慢了,无法使用抽象的例子。
我有一个非常标准的OPML文件,内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<opml version="1.0">
<!-- OPML generated by Fever -->
<head><title>Fever // Coffee</title></head>
<body>
<outline type="rss" text="I Love Coffee" title="I Love Coffee" xmlUrl="http://en.ilovecoffee.jp/posts/rss" htmlUrl="http://www.ilovecoffee.jp"/>
<outline type="rss" text="Dear Coffee I Love You" title="Dear Coffee I Love You" xmlUrl="http://feeds.feedburner.com/DearCoffeeILoveYou" htmlUrl="http://www.dearcoffeeiloveyou.com"/>
</body>
</opml>
我正在使用最简单的代码生成Markdown列表:
foreach ($opml->body->outline as $feed) {
echo '* [' . $feed['title'] . '](' . $feed[htmlUrl] . ')' . "\n";
}
我只想按“标题”属性对列表进行排序,但我无法理解如何操作。
我的理解是我需要将xml对象转换为数组,我可以这样做:
$json = json_encode($opml);
$xml_array = json_decode($json,TRUE);
但我似乎无法通过“标题”
对该数组进行排序答案 0 :(得分:0)
不是试图盲目地将整个XML文档转换为数组(很少是一个特别有用的数组),而应该构建一个包含所需项目的数组:
$feed_list = array();
foreach ($opml->body->outline as $feed) {
$feed_list[] = $feed;
}
然后,您可以使用usort()
按照您想要的任何条件对项目进行排序,例如使用strcasecmp()
给出不区分大小写的字母数字顺序:
usort($feed_list, function($a, $b) {
// $a and $b are SimpleXMLElement objects which are being sorted
return strcasecmp( (string)$a['title'], (string)$b['title'] );
});
您现在有一个已排序的数组可传递给现有的显示逻辑:
foreach ( $feed_list as $feed ) {
echo '* [' . $feed['title'] . '](' . $feed['htmlUrl'] . ')' . "\n";
}