-
- $arr1 = 배열(1,9,5);
- $arr2 = 배열(6,2,4)
- array_multisort($arr1, $arr2);
- print_r($arr1); // 얻은 순서는 1,5,9입니다.
- print_r($arr2) // 얻은 순서는 6,4,2입니다.
코드 복사
두 배열의 값이 처음부터 끝까지 일치한다고 추정합니다. 1은 6에 해당하고, 9는 2에 해당하고, 5는 4에 해당합니다.
배열을 하나 더 추가하면 어떤 일이 일어나는지 살펴보겠습니다.
-
- $arr1 = 배열(1,9,5);
- $arr2 = 배열(6,2,4); = array(3,7,8);
- array_multisort($arr1,$arr2,$arr3);
-
코드 복사
결과 보기, 1 처음부터 끝까지 모두 6~3에 해당하며, 다른 항목도 마찬가지이다. 이 대응은 매뉴얼에서 "정렬 중 원래 키 이름 연결 유지"라고 부르는 것입니다.
또는 각 배열을 데이터베이스 테이블의 열로 생각할 수 있습니다. 해당 1,6,3은 하나의 데이터 행이고, 9,2,7은 또 다른 데이터 행입니다. . .
array_multisort는 첫 번째 배열(열로 상상)을 기준으로 먼저 정렬하고, 첫 번째 배열(열)의 값이 동일하면 두 번째 배열(열)을 기준으로 정렬합니다.
시험:
- $arr1 = 배열(1,9,5,9)
- $arr2 = 배열(6,2,4,1); 🎜>$arr3 = array(3,7,8,0);
- array_multisort($arr1,$arr2,$arr3);
-
-
코드 복사
여기서 $arr3의 결과는 (3,8,0,7)이라고 상상할 수 있습니다.
2. array_multisort의 매개변수.
가장 간단한 경우는 위에 표시된 대로 1개 또는 n개의 배열을 매개변수로 사용하는 것입니다. 각 배열의 항목 수는 동일해야 하며, 그렇지 않으면 경고로 인해 정렬이 실패합니다.
다음과 같이 array_multisort($arr1,$arr2,$arr3); 기본적으로 모든 배열은 오름차순으로 정렬됩니다. $arr2를 내림차순으로 정렬하고 문자열로 비교하려면 다음을 작성해야 합니다.
array_multisort($arr1, $arr2, SORT_DESC, SORT_STRING, $arr3);
각 배열 뒤에는 정렬 순서 플래그, 정렬 유형 플래그 또는 두 플래그가 동시에 올 수 있습니다. 그러나 각 배열 뒤에는 각 유형별로 하나의 정렬 플래그만 나타날 수 있습니다.
정렬 순서 플래그:
SORT_ASC - 오름차순 정렬(기본값)
SORT_DESC - 내림차순으로 정렬
정렬 유형 플래그:
SORT_REGULAR - 항목을 정상적으로 비교합니다(기본값)
SORT_NUMERIC - 항목을 숫자로 비교합니다.
SORT_STRING - 문자열로 항목 비교
3. array_multisort의 실제 기능
일반적으로 정렬해야 하는 다차원 배열이 있습니다.
$guys = 배열 - (
- [0] => 배열
- (
- [name] => jake
- [score] => 80
- [grade] => A
- )
- [1] => Array
- (
- [name] => jin
- [score] => 70
- [등급] => A
- )
- [2] => 배열
- (
- [이름] => john
- [ 점수] => ; 80
- [등급] => A
- )
- [3] => 배열
- (
- [이름] => ben
- [점수] =>
- [학년] => B
- )
- )
-
-
코드 복사
PHP 배열 함수 array_multisort() 사용에 대해 다음 기사를 읽을 수도 있습니다.
php 배열 함수 array_map, array_multisort 다차원 배열 정렬 예제
PHP 배열 정렬 함수 array_multisort와 uasort의 차이점
PHP 배열 함수 array_multisort() 사용법
PHP에서 array_multisort() 사용 예
예를 들어 성적을 기준으로 내림차순으로 정렬하고 싶은 경우, 성적이 동일할 경우 이름을 기준으로 오름차순으로 정렬하면 됩니다. 이때 $guys의 순서에 따라 두 개의 배열을 더 만들어야 합니다. $scores = array(80,70,80,20);$names = array('jake','jin','john',' ben ');그러면 array_multisort($scores, SORT_DESC, $names, $guys); 그게 다입니다. 정렬할 때마다 추가 배열을 가져와야 합니까? 실제로 이는 qeephp의 helper_array 클래스에 잘 캡슐화되어 있습니다. 다음은 두 가지 방법을 사용할 때 약간 수정할 수 있습니다.
-
- /**
- * 根据指정적 键对数组排序
- *
- * 용법:
- * @code php
- * $rows = array(
- * array('id' => 1 , '값' => '1-1', '부모' => 1),
- * array('id' => 2, '값' => '2-1', '부모 ' => 1),
- * array('id' => 3, 'value' => '3-1', 'parent' => 1),
- * array('id ' => 4, '값' => '4-1', '부모' => 2),
- * array('id' => 5, '값' => 1', '부모' => 2),
- * array('id' => 6, '값' => '6-1', '부모' => 3),
- * );
- *
- * $rows = Helper_Array::sortByCol($rows, 'id', SORT_DESC);
- * 덤프($rows);
- * // 출력형 果为:
- * // array(
- * // array('id' => 6, 'value' => '6-1', 'parent' = > 3),
- * // array('id' => 5, 'value' => '5-1', 'parent' => 2),
- * // array( 'id' => 4, 'value' => '4-1', 'parent' => 2),
- * // array('id' => 3, 'value' => ; '3-1', '부모' => 1),
- * // array('id' => 2, '값' => '2-1', '부모' => 1),
- * // array('id' => 1, 'value' => '1-1', 'parent' => 1),
- * // )
- * @endcode
- *
- * @param array $array 要排序的数组
- * @param string $keyname 排序的键
- * @param int $dir 排序方向
- *
- * @return 배열 排序后的数组
- */
- 정적 함수 sortByCol($array, $keyname, $dir = SORT_ASC )
- {
- return self::sortByMultiCols($array, array($keyname => $dir))
- } /**
- * SQL 문의 ORDER BY와 유사하게 여러 열로 2차원 배열을 정렬합니다.
- *
- * 사용법:
- * @code php
- * $rows = Helper_Array:: sortByMultiCols ($rows, array(
- * '부모' => SORT_ASC,
- * '이름' => SORT_DESC,
- * )); * @param array $rowset 정렬할 배열
- * @param array $args 정렬할 키
- *
- * @return array 정렬된 배열
- */
- 정적 함수 sortByMultiCols($rowset , $args)
- {
- $sortArray = array();
- $sortRule = ''
- foreach ($args as $sortField => $sortDir)
- {
- foreach ($rowset as $offset => $row)
- {
- $sortArray[$sortField][$offset] = $row[$sortField]
- }
- $sortRule .= ' $sortArray['' . ''], ' . $sortDir . ', ';
- if (empty($sortArray) || 비어 있음($sortRule))
- eval('array_multisort(' . $sortRule . '$rowset);');
- return $rowset;
- }
-
-
- 코드 복사
-
|