php - 在 php 中对包含日期的数组进行排序

标签 php

我有一个数组,因此我想按日期对这个数组进行排序如何对这个数组进行排序

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

我使用过 usort 但它不起作用,我正在编写一个函数并将其转换为 strtotime 但它不起作用。任何建议。

最佳答案

尝试以下解决方案:

$array = array
(
    0 => '28/02/2016',
    1 => '30/01/2016',
    2 => '16/02/2016',
    3 => '19/02/2016',
    4 => '24/02/2016',
    5 => '13/02/2016',
    6 => '18/02/2016',
    7 => '27/02/2016',
    8 => '25/02/2016',
    9 => '01/02/2016',
    10 => '02/02/2016',
    11 => '03/02/2016',
    12 => '05/02/2016',
    13 => '06/02/2016',
    14 => '07/02/2016',
    15 => '08/02/2016',
    16 => '11/02/2016',
    17 => '12/02/2016'
);

function sortFunction( $a, $b ) {
    $date1 = DateTime::createFromFormat('d/m/Y', $a);

    $date2 = DateTime::createFromFormat('d/m/Y', $b);
    return $date1->getTimestamp() - $date2->getTimestamp();
}
usort($array, "sortFunction");
print_r($array);

输出

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

关于php - 在 php 中对包含日期的数组进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36171946/

相关文章:

javascript - 在ajax结果中得到这个

php - Laravel Eloquent all() 在不同服务器上的不同排序顺序

php - 选择多个条件

PHP PDO - 可以连接但查询不工作

php - 对数组值求和

php - 插入查询在我的程序中不起作用,但在 mysql 选项卡上运行良好

PHP 数组的最大长度

php - 如何匹配 php 中包含具有固定数量的字母数字字符的 https url 的字符串?

php - 多次插入不适用于 INNODB

php - 无法跳转到第 0 行