1. 먼저 가장 간단한 상황부터 살펴보겠습니다. 두 개의 배열이 있습니다:
$arr1 = array(1,9,5); $arr2 = array(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 = array(1,9,5); $arr2 = array(6,2,4); $arr3 = array(3,7,8); array_multisort($arr1,$arr2,$arr3);
3. 다른 항목에도 마찬가지입니다. 이 대응은 매뉴얼에서 "정렬 중 원래 키 이름 연결 유지"라고 부르는 것입니다.
또한 각 배열을 데이터베이스 테이블의 열로 생각할 수도 있습니다. 해당 1,6,3은 하나의 데이터 행이고, 9,2,7은 또 다른 데이터 행입니다. . .
array_multisort는 먼저 첫 번째 배열(열로 상상)을 기준으로 정렬합니다. 첫 번째 배열(열)의 값이 동일하면 두 번째 배열(열)을 기준으로 정렬합니다.
다음 프로그램을 사용하여 테스트할 수 있습니다.
$arr1 = array(1,9,5,9); $arr2 = array(6,2,4,1); $arr3 = array(3,7,8,0); array_multisort($arr1,$arr2,$arr3);
출력:
Array ( [0] => 1 [1] => 5 [2] => 9 [3] => 9 ) Array ( [0] => 6 [1] => 4 [2] => 1 [3] => 2 ) Array ( [0] => 3 [1] => 8 [2] => 0 [3] => 7 )
여기서 $arr1이 정상적으로 오름차순으로 정렬된 것을 확인할 수 있습니다. 그러나 $arr2와 $arr3은 정렬되지 않았습니다.
그런데 자세히 살펴보니 이 세 배열의 각 요소가 실제로 1:1로 대응되는 것을 발견했습니다.
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 = Array( [0] => Array ( [name] => jake [score] => 80 [grade] => A ) [1] => Array ( [name] => jin [score] => 70 [grade] => A ) [2] => Array ( [name] => john [score] => 80 [grade] => A ) [3] => Array ( [name] => ben [score] => 20 [grade] => B ) )
예를 들어 다음과 같습니다. 성적이 같으면 역순으로 정렬합니다. 이름순으로 오름차순으로 정렬하면 됩니다.
이번에는 $guys 순서에 따라 두 개의 배열을 더 생성해야 합니다. >
$scores = array(80,70,80,20); $names = array('jake','jin','john','ben');
그렇습니다.
그렇습니다. 더 유연할까요? 정렬할 때마다 추가 배열을 가져와야 합니까?실제로 qeephp의 helper_array 클래스에 잘 캡슐화되어 있습니다. 필요한 사람은 이를 직접 수정할 수 있습니다.
array_multisort($scores, SORT_DESC, $names, $guys);
/** * 根据指定的键对数组排序 * * 用法: * @code php * $rows = array( * array('id' => 1, 'value' => '1-1', 'parent' => 1), * array('id' => 2, 'value' => '2-1', 'parent' => 1), * array('id' => 3, 'value' => '3-1', 'parent' => 1), * array('id' => 4, 'value' => '4-1', 'parent' => 2), * array('id' => 5, 'value' => '5-1', 'parent' => 2), * array('id' => 6, 'value' => '6-1', 'parent' => 3), * ); * * $rows = Helper_Array::sortByCol($rows, 'id', SORT_DESC); * dump($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', 'parent' => 1), * // array('id' => 2, 'value' => '2-1', 'parent' => 1), * // array('id' => 1, 'value' => '1-1', 'parent' => 1), * // ) * @endcode * * @param array $array 要排序的数组 * @param string $keyname 排序的键 * @param int $dir 排序方向 * * @return array 排序后的数组 */ static function sortByCol($array, $keyname, $dir = SORT_ASC) { return self::sortByMultiCols($array, array($keyname => $dir)); }