按日期键按子数组排序PHP数组

时间:2015-01-06 23:07:18

标签: php arrays

我知道这个问题已被问了一百次,而且我已经通过了多个答案而没有得到正确的结果。

我正在尝试按日期排序以下第一行:

Array(
[0] => Array
    (
        [0] => '3173'
        [1] => 'Contact - 12-6-14 Outstanding invoice'
        [2] => '16/06/2014'
        [3] => '204'
    )

[1] => Array
    (
        [0] => '3167'
        [1] => 'Contact - Outstanding invoice'
        [2] => '13/06/2014'
        [3] => '207'
    )

[2] => Array
    (
        [0] => '3497'
        [1] => 'New Site - Keri Keri'
        [2] => '25/11/2014'
        [3] => '43'
    )

[3] => Array
    (
        [0] => '2023'
        [1] => 'Analysis'
        [2] => '17/06/2014'
        [3] => '355'
    )

[4] => Array
    (
        [0] => '2641'
        [1] => 'PSS'
        [2] => '20/02/2014'
        [3] => '321'
    )

我已经尝试过如下的事情而没有运气。

function cmp($a, $b){
      return $b[2] - $a[2];
   } 

usort($urgent_array, "cmp");

对此人的任何帮助都会非常感激:)

2 个答案:

答案 0 :(得分:0)

首先,你要比较而不是减去:

function cmp($a, $b) {
    if ($a[2] == $b[2])
        return 0;
    return ($a[2] > $b[2]) ? 1 : -1;
} 

usort($urgent_array, "cmp");

然后,如果您使用Y-m-d格式,则日期排序效果最佳:

2014-06-13等。

答案 1 :(得分:0)

将比较功能更改为

function cmp($a, $b){
    $a_date = strtotime(str_replace('/', '-', $a[2]));
    $b_date = strtotime(str_replace('/', '-', $b[2]));

    return $a_date - $b_date;
}

你想使用strtotime,因为减去字符串并不意味着什么。 str_replace是因为PHP期望破折号为dd-mm-yyyy格式。