dsjq6977
2017-01-09 08:17
浏览 148
已采纳

我如何在PHP中按日期排序数组

I have this array and i want to sort it in ascending order by date. I tried various answers from this site but none of them is working right. So how can I do this?

Array
(
    [0] => 09/01/2017
    [1] => 08/01/2017
    [2] => 07/01/2017
    [3] => 06/01/2017
    [4] => 05/01/2017
    [5] => 04/01/2017
    [6] => 03/01/2017
    [7] => 02/01/2017
    [8] => 01/01/2017
    [9] => 12/12/2016
    [10] => 11/12/2016
    [11] => 10/12/2016
    [12] => 09/12/2016
    [13] => 25/12/2016
    [14] => 24/12/2016
    [15] => 23/12/2016
    [16] => 26/12/2016
    [17] => 28/12/2016
    [18] => 30/12/2016
    [19] => 29/12/2016
    [20] => 22/12/2016
    [21] => 27/12/2016
    [22] => 15/12/2016
    [23] => 16/12/2016
    [24] => 14/12/2016
    [25] => 13/12/2016
    [26] => 17/12/2016
    [27] => 18/12/2016
    [28] => 20/12/2016
    [29] => 19/12/2016
    [30] => 21/12/2016
)

I am using PHP. This is what i tried so far. This function doesn't sort as mentioned in all other questions.

$data = array listed above;
function cmp($a, $b)
{
    if (strtotime($a) == strtotime($b))
    {
        return 0;
    }
    return (strtotime($a) < strtotime($b)) ? -1 : 1;
}

uasort($data, "cmp");

图片转代码服务由CSDN问答提供 功能建议

我有这个数组,我希望按日期按升序对其进行排序。 我尝试了这个网站的各种答案,但没有一个正常工作。 那我怎么能这样做呢?

  Array 
(
 [0] =&gt; 09/01/2017 
 [1] =&gt; 08/01 /  2017 
 [2] =&gt; 07/01/2017 
 [3] =&gt; 06/01/2017 
 [4] =&gt; 05/01/2017 
 [5] =&gt; 04 /  01/2017 
 [6] =&gt; 03/01/2017 
 [7] =&gt; 02/01/2017 
 [8] =&gt; 01/01/2017 
 [9] =&gt;  2016年12月12日
 [10] =&gt; 11/12/2016 
 [11] =&gt; 10/12/2016 
 [12] =&gt; 09/12/2016 
 [13] =  &gt; 25/12/2016 
 [14] =&gt; 24/12/2016 
 [15] =&gt; 2016年12月23日
 [16] =&gt; 2016年12月26日
 [17  ] =&gt; 28/12/2016 
 [18] =&gt; 30/12/2016 
 [19] =&gt; 2016年12月29日
 [20] =&gt; 22/12/2016 
  [21] =&gt; 2016年12月27日
 [22] =&gt; 15/12/2016 
 [23] =&gt; 2016年12月16日
 [24] =&gt; 14/12/2016  
 [25] =&gt; 13/12/2016 
 [26] =&gt; 2016年12月17日
 [27] =&gt; 2016年12月18日
 [28] =&gt; 20/12  / 2016 
 [29] =&gt; 19/12/2016 
 [30] =&gt; 21/12/2016 
)
   
 
 

我是 使用PHP。 这是我到目前为止所尝试的。 这个函数没有像所有其他问题中提到的那样排序。

  $ data =上面列出的数组; 
 cmp($ a,$ b)
 {
 if  (strtotime($ a)== strtotime($ b))
 {
返回0; 
} 
返回(strtotime($ a)&lt; strtotime($ b))?  -1:1; 
} 
 
uasort($ data,“cmp”); 
   
 
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

4条回答 默认 最新

  • douniang3866 2017-01-09 08:30
    已采纳

    For you string is dd/mm/yy type, cannot directly used by strtotime or date_create. You can use DataTime to create the datetime, then use the datetime compare operators.

    usort($array, function($a, $b){return DateTime::createFromFormat('d/m/Y', $a) > DateTime::createFromFormat('d/m/Y', $b);});
    
    已采纳该答案
    打赏 评论
  • dongtazu3080 2017-01-09 08:26
    $document_list = array( array );
    $document_list= array_map(function($v) {
        return date('Y-m-d', strtotime($v));
    }, $document_list);
    
    function sortByDate($a, $b) {
        return  strtotime($b) - strtotime($a);
    }
    
    usort($document_list, "sortByDate");
    
    $document_list= array_map(function($v) {
        return date('m-d-Y', strtotime($v));
    }, $document_list);
    
    打赏 评论
  • douju2053 2017-01-09 08:40
    function desc_date_sort($a, $b){
        $date1ts = DateTime::createFromFormat('d/m/Y', $a);
        $date2ts = DateTime::createFromFormat('d/m/Y', $b);
        return $date1ts === $date2ts ? 0 : ( $date1ts < $date2ts ? 1 : -1 ); 
    }
    usort($dates_array, 'desc_date_sort');
    
    打赏 评论
  • dongliao6491 2017-01-09 08:41
    function cmp($a,$b){
        return strtotime($a['created'])<strtotime($b['created'])?1:-1;
    };
    // $array pass your array name
    uasort($array,'cmp');
    
    打赏 评论

相关推荐 更多相似问题