按未正确排序的值对多维数组进行排序


Sort multidimensional array by value not sorting correctly

我试图按日期ASC对多维数组进行排序,但遇到了问题。。。所以我想问你们,为什么会发生这种事?

我的代码是(运行于:Codepad示例):

$data = array (
          array (
            'date' => '2016-03-11 12:10:17',
            'type' => '1'
          ),
          array (
            'date' => '2016-03-12 07:16:25',
            'type' => '1'
          ),
          array (
            'date' => '2016-03-12 07:18:07',
            'type' => '2'
          ),
          array (
            'date' => '2016-03-09 14:57:42',
            'type' => '2'
          ),
          array (
            'date' => '2016-02-22 10:39:39',
            'type' => '1'
          )
    );
    usort($data, function($a, $b) {
        return $a['date'] - $b['date'];
    });
    echo '<pre>';
    var_dump($data);

问题是排序不好,我的意思是需要从2月到3月,但没有这样做,我不知道为什么。

非常感谢您的帮助!。

使用文档中的排序:http://php.net/manual/en/function.usort.php

usort($data, function($a, $b) {
    if ($a['date'] == $b['date']) {
        return 0;
    }
    return ($a['date'] < $b['date']) ? -1 : 1;
});

您比较的是字符串,而不是数字,因此会得到意外的结果。

要比较两个字符串,可以使用strcmp:

usort( $data, function( $a, $b ) {
    return strcmp( $a['date'], $b['date'] );
});

CCD_ 2返回<如果第一个arg小于第二个,则为0;>如果第一个arg大于第二个,则为0;如果它们相等,则为零。