값으로 다차원 배열을 정렬하는 방법?
"order"키의 값으로이 배열을 어떻게 정렬 할 수 있습니까? 값이 현재 순차적이지만 항상 그런 것은 아닙니다.
Array
(
[0] => Array
(
[hashtag] => a7e87329b5eab8578f4f1098a152d6f4
[title] => Flower
[order] => 3
)
[1] => Array
(
[hashtag] => b24ce0cd392a5b0b8dedc66c25213594
[title] => Free
[order] => 2
)
[2] => Array
(
[hashtag] => e7d31fc0602fb2ede144d18cdffd816b
[title] => Ready
[order] => 1
)
)
usort를 사용해보십시오. 아직 PHP 5.2 이전 버전을 사용하고 있다면 먼저 정렬 함수를 정의해야합니다.
function sortByOrder($a, $b) {
return $a['order'] - $b['order'];
}
usort($myArray, 'sortByOrder');
PHP 5.3부터 익명 함수를 사용할 수 있습니다.
usort($myArray, function($a, $b) {
return $a['order'] - $b['order'];
});
마지막으로 PHP 7에서는 우주선 연산자를 사용할 수 있습니다 .
usort($myArray, function($a, $b) {
return $a['order'] <=> $b['order'];
});
이를 다차원 정렬로 확장하려면 첫 번째가 0 인 경우 두 번째 / 세 번째 정렬 요소를 참조하십시오. 아래에 가장 잘 설명되어 있습니다. 하위 요소 정렬에도 사용할 수 있습니다.
usort($myArray, function($a, $b) {
$retval = $a['order'] <=> $b['order'];
if ($retval == 0) {
$retval = $a['suborder'] <=> $b['suborder'];
if ($retval == 0) {
$retval = $a['details']['subsuborder'] <=> $b['details']['subsuborder'];
}
}
return $retval;
});
키 연결을 유지해야하는 경우 사용 uasort()
하십시오- 설명서 의 배열 정렬 기능 비교 참조
function aasort (&$array, $key) {
$sorter=array();
$ret=array();
reset($array);
foreach ($array as $ii => $va) {
$sorter[$ii]=$va[$key];
}
asort($sorter);
foreach ($sorter as $ii => $va) {
$ret[$ii]=$array[$ii];
}
$array=$ret;
}
aasort($your_array,"order");
이 기능을 사용합니다.
function array_sort_by_column(&$arr, $col, $dir = SORT_ASC) {
$sort_col = array();
foreach ($arr as $key=> $row) {
$sort_col[$key] = $row[$col];
}
array_multisort($sort_col, $dir, $arr);
}
array_sort_by_column($array, 'order');
I usually use usort, and pass my own comparison function. In this case, it is very simple:
function compareOrder($a, $b)
{
return $a['order'] - $b['order'];
}
usort($array, 'compareOrder');
One approach to achieve this would be like this
$new = [
[
'hashtag' => 'a7e87329b5eab8578f4f1098a152d6f4',
'title' => 'Flower',
'order' => 3,
],
[
'hashtag' => 'b24ce0cd392a5b0b8dedc66c25213594',
'title' => 'Free',
'order' => 2,
],
[
'hashtag' => 'e7d31fc0602fb2ede144d18cdffd816b',
'title' => 'Ready',
'order' => 1,
],
];
$keys = array_column($new, 'order');
array_multisort($keys, SORT_ASC, $new);
var_dump($new);
Result:
Array
(
[0] => Array
(
[hashtag] => e7d31fc0602fb2ede144d18cdffd816b
[title] => Ready
[order] => 1
)
[1] => Array
(
[hashtag] => b24ce0cd392a5b0b8dedc66c25213594
[title] => Free
[order] => 2
)
[2] => Array
(
[hashtag] => a7e87329b5eab8578f4f1098a152d6f4
[title] => Flower
[order] => 3
)
)
$sort = array();
$array_lowercase = array_map('strtolower', $array_to_be_sorted);
array_multisort($array_lowercase, SORT_ASC, SORT_STRING, $alphabetically_ordered_array);
This takes care of both upper and lower case alphabets.
To sort the array by the value of the "title" key use:
uasort($myArray, function($a, $b) {
return strcmp($a['title'], $b['title']);
});
strcmp compare the strings.
uasort() maintains the array keys as they were defined.
The most flexible approach would be using this method
Arr::sortByKeys(array $array, $keys, bool $assoc = true): array
here's why:
You can sort by any key (also nested like
'key1.key2.key3'
or['k1', 'k2', 'k3']
)Works both on associative and not associative arrays (
$assoc
flag)It doesn't use reference - return new sorted array
In your case it would be as simple as:
$sortedArray = Arr::sortByKeys($array, 'order');
This method is a part of this library.
Use array_multisort(), array_map()
array_multisort(array_map(function($element) {
return $element['order'];
}, $array), SORT_ASC, $array);
print_r($array);
Let's face it: php does NOT have a simple out of the box function to properly handle every array sort scenario.
This routine is intuitive, which means faster debugging and maintenance:
// automatic population of array
$tempArray = array();
$annotations = array();
// ... some code
// SQL $sql retrieves result array $result
// $row[0] is the ID, but is populated out of order (comes from
// multiple selects populating various dimensions for the same DATE
// for example
while($row = mysql_fetch_array($result)) {
$needle = $row[0];
arrayIndexes($needle); // create a parallel array with IDs only
$annotations[$needle]['someDimension'] = $row[1]; // whatever
}
asort($tempArray);
foreach ($tempArray as $arrayKey) {
$dataInOrder = $annotations[$arrayKey]['someDimension'];
// .... more code
}
function arrayIndexes ($needle) {
global $tempArray;
if (!in_array($needle,$tempArray)) {
array_push($tempArray,$needle);
}
}
참고URL : https://stackoverflow.com/questions/2699086/how-to-sort-multi-dimensional-array-by-value
'your programing' 카테고리의 다른 글
jQuery에서 이벤트 핸들러를 제거하는 가장 좋은 방법은 무엇입니까? (0) | 2020.09.27 |
---|---|
고정 헤더에 맞게 조정하기 위해 html 앵커 오프셋 (0) | 2020.09.27 |
삽입 된 행의 ID를 얻는 가장 좋은 방법은 무엇입니까? (0) | 2020.09.27 |
파이썬에서 '자아'라는 단어의 목적은 무엇입니까? (0) | 2020.09.27 |
"올바른"JSON 날짜 형식 (0) | 2020.09.27 |