Упорядочить массив PHP по подмассиву по ключу даты

0

Я знаю, что этот вопрос задавали сто раз, и я прошел несколько ответов и не получил правильных результатов.

Я пытаюсь заказать следующую строку по дате, старейшую сначала:

Array(
[0] => Array
    (
        [0] => '3173'
        [1] => 'Contact - 12-6-14 Outstanding invoice'
        [2] => '16/06/2014'
        [3] => '204'
    )

[1] => Array
    (
        [0] => '3167'
        [1] => 'Contact - Outstanding invoice'
        [2] => '13/06/2014'
        [3] => '207'
    )

[2] => Array
    (
        [0] => '3497'
        [1] => 'New Site - Keri Keri'
        [2] => '25/11/2014'
        [3] => '43'
    )

[3] => Array
    (
        [0] => '2023'
        [1] => 'Analysis'
        [2] => '17/06/2014'
        [3] => '355'
    )

[4] => Array
    (
        [0] => '2641'
        [1] => 'PSS'
        [2] => '20/02/2014'
        [3] => '321'
    )

)

Я пробовал такие вещи, как ниже, без везения.

function cmp($a, $b){
      return $b[2] - $a[2];
   } 

usort($urgent_array, "cmp");

Любая помощь на этом была бы оценена по достоинству :)

Теги:
arrays
order

2 ответа

0
Лучший ответ

Во-первых, вы хотите сравнить, а не вычесть:

function cmp($a, $b) {
    if ($a[2] == $b[2])
        return 0;
    return ($a[2] > $b[2]) ? 1 : -1;
} 

usort($urgent_array, "cmp");

Затем упорядочение дат лучше всего подходит, если вы используете формат Ymd:

2014-06-13 и т.д.

  • 0
    Ooops моя ошибка, поставив 2, это было 3. Не работает, хотя, массив просто возвращается пустым
  • 0
    @ SeánMcCabe, как насчет других изменений - используя операторы сравнения, такие как < и > вместо того, чтобы вычитать и ставить год первым?
Показать ещё 2 комментария
0

Измените функцию сравнения на

function cmp($a, $b){
    $a_date = strtotime(str_replace('/', '-', $a[2]));
    $b_date = strtotime(str_replace('/', '-', $b[2]));

    return $a_date - $b_date;
}

Вы хотите использовать strtotime, потому что вычитание строк на самом деле ничего не значит. Str_replace - это потому, что PHP ожидает тире для формата dd-mm-yyyy.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню