按日期在PHP中排序json数组?

时间:2013-10-20 22:05:50

标签: php json parsing sorting

我正在尝试对已从xml(rss)转换为json的新闻项列表进行排序。我希望在合并供稿后按日期顺序对它们进行排序,但我不确定实现它的最佳方法。

json响应如下:

{ "success":true,
"message":"",
"data":{
"title":"Feed Name",
"item":[{
"title":"test",
"pubdate":"Sun, 20 Oct 2013 21:36:42 GMT"}]
}
}

1 个答案:

答案 0 :(得分:5)

要在PHP中执行此操作,首先要将其解码为PHP数组:

 $data = json_decode($yourJsonVariable, true);

现在使用上面的数据,这将为您提供一个类似于:

的数组
 array(
   'success' => true,
   'data' => array(
     'title' => 'Feed Name',
     'item' => array(
       0 => array(
         'title' => 'test',
         'pubdate' => 'Sun, 20 Oct 2013 21:36:42 GMT'
       )
     )
   )
 )

因此,使用它,您可以弄清楚您希望排序功能如何工作。但是,不清楚的是,如果您只是尝试对item数组的元素进行排序,或者您尝试进行更复杂的排序(因为您提到“当组合了Feed时”)。< / p>

仅对item数组进行排序是一项相当简单的任务,正弦每个元素只是一个包含两个元素的数组,一个名为title,另一个名为pubdate。在这种情况下,您的sort函数类似于:

 usort($data['data']['item'], function($a, $b) {
   return (strtotime($a['pubdate']) < strtotime($b['pubdate']) -1 : 1);
 });

如果您需要对整个数组或其中的不同部分进行排序,您应该能够调整该功能。