按日期排序关联数组


Sorting Associative Array by Date

我在php中有这个数组之王,并希望按数组的日期数组[I][2]进行排序。最高日期应该在上面…我该怎么做呢?

这是我的数组:

Array ( 
    [0] => Array ( 
        [0] => 15.04.2013 
        [1] => 17:34 
        [2] => 06.04.2013 
        ) 
    [1] => Array ( 
        [0] => 15.04.2013 
        [1] => 15:12 
        [2] => 13.04.2013 
    ) 
    [2] => Array ( 
        [0] => 15.04.2013 
        [1] => 16:42 
        [2] => 16.02.2013 
    ) 
    [3] => Array ( 
        [0] => 04.04.2013 
        [1] => 21:12 
        [2] => 16.03.2013 
    ) 
    [4] => Array ( 
        [0] => 29.04.2013 
        [1] => 17:16 
        [2] => 19.04.2013 
    ) 
) 

你可以使用ussort

的例子:

usort($array,function ($a,$b){
    $t1 = strtotime($a[0]);
    $t2 = strtotime($b[0]);
    if ($t1 == $t2) {
        return 0;
    }
    return ($t1 < $t2) ? -1 : 1;
});

您可以使用usort(),如下所示:

function cmp($a,$b) {
   if ($a[2] == $b[2]) {
      return 0;
   }
   $arr = explode('.',$a[2]);
   $brr = explode('.',$b[2]);
   $anum = (int) ($arr[2] . $arr[1] . $arr[0]);
   $bnum = (int) ($brr[2] . $brr[1] . $brr[0]);
   return ($anum < $bnum) ? -1 : 1;
}
usort($array, "cmp");

试试这个:

function cmp($a, $b)
{
    $a = strtotime($a[2]);
    $b = strtotime($b[2]);
    if ($a == $b) {
        return 0;
    }
    return ($a < $b) ? -1 : 1;
}
$a = array ( 
    0 => array ( 
        0 => '15.04.2013' 
        ,1 => '17:34'
        ,2 => '06.04.2013' 
        ) 
    ,1 => array ( 
        0 => '15.04.2013' 
        ,1 => '15:12' 
        ,2 => '13.04.2013' 
    ) 
    ,2 => array ( 
        0 => '15.04.2013' 
        ,1 => '16:42' 
        ,2 => '16.02.2013' 
    ) 
    ,3 => array ( 
        0 => '04.04.2013' 
        ,1 => '21:12' 
        ,2 => '16.03.2013' 
    ) 
) ;
usort($a, "cmp");

您可以通过使用ussort(就像在lbu的回答中一样)来编写自定义排序器回调

array_multisort是另一种选择,使用like;

这是一个多维数组的排序函数

https://gist.github.com/tufanbarisyildirim/1220785