我试图按日期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;如果它们相等,则为零。