다음과 같은 배열이 있습니다.
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]);
});
![](http://daplus.net/wp-content/uploads/2023/04/coupang_part-e1630022808943-2.png)