[php] PHP 날짜를 포함하는 요소로 다차원 배열 정렬

다음과 같은 배열이 있습니다.

Array
(
[0] => Array
    (
        [id] => 2
        [type] => comment
        [text] => hey
        [datetime] => 2010-05-15 11:29:45
    )

[1] => Array
    (
        [id] => 3
        [type] => status
        [text] => oi
        [datetime] => 2010-05-26 15:59:53
    )

[2] => Array
    (
        [id] => 4
        [type] => status
        [text] => yeww
        [datetime] => 2010-05-26 16:04:24
    )

)

누구든지 datetime 요소를 기반으로 정렬 / 순서하는 방법을 제안 할 수 있습니까?



답변

사용 usort()및 사용자 지정 비교 기능 :

function date_compare($a, $b)
{
    $t1 = strtotime($a['datetime']);
    $t2 = strtotime($b['datetime']);
    return $t1 - $t2;
}
usort($array, 'date_compare');

편집 : 데이터는 배열 배열로 구성됩니다. 이들을 더 잘 구별하기 위해 내부 배열 (데이터) 레코드를 호출하여 데이터가 실제로 레코드 배열이되도록합니다.

usort이 레코드 중 두 개를 주어진 비교 함수 date_compare()에 한 번에 전달합니다. date_compare그런 다음 "datetime"각 레코드 의 필드를 UNIX 타임 스탬프 (정수) 로 추출하고 차이를 반환하므로 결과는 0두 날짜가 같으면 양수, 첫 번째 날짜 ( $a)가 크면 양수, 그렇지 않으면 음수 값이됩니다. 두 번째 인수 ( $b)가 더 큽니다. usort()이 정보를 사용하여 배열을 정렬합니다.


답변

작동합니다. strtotime을 통해 날짜를 유닉스 시간으로 변환했습니다.

  foreach ($originalArray as $key => $part) {
       $sort[$key] = strtotime($part['datetime']);
  }
  array_multisort($sort, SORT_DESC, $originalArray);

한 줄 버전은 여러 배열 방법을 사용합니다.

array_multisort(array_map('strtotime',array_column($originalArray,'datetime')),
                SORT_DESC,
                $originalArray);


답변

php7에서 우주선 연산자를 사용할 수 있습니다 .

usort($array, function($a, $b) {
  return new DateTime($a['datetime']) <=> new DateTime($b['datetime']);
});


답변

http://us2.php.net/manual/en/function.array-multisort.php
세 번째 예제 참조 :

<?php

$data[] = array('volume' => 67, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 1);
$data[] = array('volume' => 85, 'edition' => 6);
$data[] = array('volume' => 98, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 6);
$data[] = array('volume' => 67, 'edition' => 7);

foreach ($data as $key => $row) {
    $volume[$key]  = $row['volume'];
    $edition[$key] = $row['edition'];
}

array_multisort($volume, SORT_DESC, $edition, SORT_ASC, $data);

?>

참고로, 유닉스 (1970 년의 초) 또는 mysql 타임 스탬프 (YmdHis-20100526014500)를 사용하는 것이 파서에게는 더 쉬울 것이지만 귀하의 경우에는 아무런 차이가 없다고 생각합니다.


답변

지정된 mysql datetime 필드 및 순서에 따라 레코드 / assoc_array 배열 정렬 :

function build_sorter($key, $dir='ASC') {
    return function ($a, $b) use ($key, $dir) {
        $t1 = strtotime(is_array($a) ? $a[$key] : $a->$key);
        $t2 = strtotime(is_array($b) ? $b[$key] : $b->$key);
        if ($t1 == $t2) return 0;
        return (strtoupper($dir) == 'ASC' ? ($t1 < $t2) : ($t1 > $t2)) ? -1 : 1;
    };
}


// $sort - key or property name 
// $dir - ASC/DESC sort order or empty
usort($arr, build_sorter($sort, $dir));


답변

$array = Array
(
  [0] => Array
   (
    [id] => 2
    [type] => comment
    [text] => hey
    [datetime] => 2010-05-15 11:29:45
   )

 [1] => Array
  (
    [id] => 3
    [type] => status
    [text] => oi
    [datetime] => 2010-05-26 15:59:53
  )

  [2] => Array
   (
    [id] => 4
    [type] => status
    [text] => yeww
    [datetime] => 2010-05-26 16:04:24
   )

   );
   print_r($array);
   $name = 'datetime';
   usort($array, function ($a, $b) use(&$name){
      return $a[$name] - $b[$name];});

   print_r($array);


답변

콜백 함수와 함께 usort () 를 사용하여이 문제를 간단히 해결할 수 있습니다 . 사용자 지정 함수를 작성할 필요가 없습니다.

$your_date_field_name = 'datetime';
usort($your_given_array_name, function ($a, $b) use (&$your_date_field_name) {
    return strtotime($a[$your_date_field_name]) - strtotime($b[$your_date_field_name]);
});