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);
결과를 보면 1이 처음부터 6, 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);
여기서 $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 = 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');
그런 다음
array_multisort($scores, SORT_DESC, $names, $guys); 그게 다입니다
원할 때마다 더 유연해질 수 있습니까? sort 추가 배열이 필요합니까?
실제로 qeephp의 helper_array 클래스에 잘 캡슐화되어 있습니다. 필요한 사람은 직접 수정하여 사용할 수 있습니다.
/** * 根据指定的键对数组排序 * * 用法: * @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)); } /** * 将一个二维数组按照多个列进行排序,类似 SQL 语句中的 ORDER BY * * 用法: * @code php * $rows = Helper_Array::sortByMultiCols($rows, array( *'parent' => SORT_ASC, *'name' => SORT_DESC, * )); * @endcode * * @param array $rowset 要排序的数组 * @param array $args 排序的键 * * @return array 排序后的数组 */ static function sortByMultiCols($rowset, $args) { $sortArray = array(); $sortRule = ''; foreach ($args as $sortField => $sortDir) { foreach ($rowset as $offset => $row) { $sortArray[$sortField][$offset] = $row[$sortField]; } $sortRule .= '$sortArray[\'' . $sortField . '\'], ' . $sortDir . ', '; } if (empty($sortArray) || empty($sortRule)) { return $rowset; } eval('array_multisort(' . $sortRule . '$rowset);'); return $rowset; }
추가 PHP array_multisort() 기능에 대한 심층 분석은 PHP 중국어 웹사이트에 주목하세요!