Вопрос

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

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

Это было полезно?

Решение

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

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

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

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

uksort($array, 'cmp');

Другие советы

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

usort($array, "cmp");

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

:)

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

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

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

// Sort in chronological order.
usort($array, function($a, $b) {
  return strcmp($a['db'], $b['db']);
});
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top