Как отсортировать массив дат в PHP - PullRequest
18 голосов
/ 28 февраля 2009

У меня есть массив в этом формате:

Array
(
    [0] => Array
        (
            [28th February, 2009] => 'bla'
        )

    [1] => Array
        (
            [19th March, 2009] => 'bla'
        )

    [2] => Array
        (
            [5th April, 2009] => 'bla'
        )

    [3] => Array
        (
            [19th April, 2009] => 'bla'
        )

    [4] => Array
        (
            [2nd May, 2009] => 'bla'
        )

) 

Я хочу отсортировать их в порядке возрастания дат (на основе месяца, дня и года). Какой лучший способ сделать это?

Изначально письма выбирались в формате даты MySQL, поэтому я могу получить массив в этом состоянии:

Array
[
    ['2008-02-28']='some text',
    ['2008-03-06']='some text'
]

Возможно, когда он находится в этом формате, я могу проходить через них, удалять все метки '-' (дефисы), чтобы они оставались целыми числами, сортировать их, используя array_sort(), и снова проходить через них, чтобы отсортировать их? Предпочел бы, если бы был другой способ, так как я бы делал 3 цикла с этим для пользователя.

Спасибо.

Редактировать: Я также мог бы сделать это:

$array[$index]=array('human'=>'28 Feb, 2009',
                   'db'=>'20080228',
                   'description'=>'Some text here');

Но, используя это, можно ли каким-либо образом отсортировать массив по одному элементу 'db'?

Редактировать 2: обновлен начальный var_dump

Ответы [ 4 ]

42 голосов
/ 28 февраля 2009

Используйте формат ISO (yyyy-mm-dd), а не "английский", а затем просто используйте функцию ksort, чтобы получить их в правильном порядке.

Нет необходимости удалять дефисы, ksort выполнит буквенно-цифровое сравнение строковых ключей, а формат yyyy-mm-dd отлично работает, так как лексический порядок совпадает с фактическим порядком дат.

РЕДАКТИРОВАТЬ Я вижу, что вы теперь исправили свой вопрос, чтобы показать, что на самом деле у вас есть массив массивов и что ключ сортировки находится во вложенных массивах. В этом случае вам следует использовать uksort, как рекомендовано в другом месте, но я бы порекомендовал вам выполнять собственное редактирование и сортировку на основе даты в формате БД, а не анализировать читабельный формат:

function cmp($a, $b)
{
    global $array;
    return strcmp($array[$a]['db'], $array[$b]['db']);
}

uksort($array, 'cmp');
10 голосов
/ 23 декабря 2010

На самом деле, используйте это:

usort($array, "cmp");

function cmp($a, $b){ 
    return strcmp($b['db'], $a['db']); 
}

:)

4 голосов
/ 08 июня 2010
function cmp($a, $b) {    
    global $array;    
    return strcmp($array[$a]['db'], $array[$b]['db']); 
}    
uksort($array, 'cmp');

Я думаю, что лучше использовать usort() функцию вместо uksort(), потому что иногда вы вообще не можете использовать глобальные переменные и в любом случае использование глобальных переменных также не является хорошей практикой.

2 голосов
/ 08 февраля 2016

Вы также можете использовать анонимную функцию.

// Sort in chronological order.
usort($array, function($a, $b) {
  return strcmp($a['db'], $b['db']);
});
...