Подтвердить что ты не робот

Как отсортировать массив даты в PHP

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

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

4b9b3361

Ответ 1

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

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

EDIT Я вижу, что теперь вы исправили свой вопрос, чтобы показать, что на самом деле у вас есть массив массивов и что ключ сортировки находится в под-массивах. В этом случае вы должны использовать uksort, как рекомендовано в других местах, но я бы рекомендовал вам перейти со своим собственным редактированием и сортировкой на основе даты в формате БД, а не путем анализа читаемого человеком формата:

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

uksort($array, 'cmp');

Ответ 2

Собственно, используйте это:

usort($array, "cmp");

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

:)

Ответ 3

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

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

Ответ 4

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

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