다차원 배열을 정렬하는 일반적인 방법은
1입니다. 정렬된 데이터를 가져와서 $arrSort 배열에 넣습니다. 키 인덱스는 정렬할 배열의 인덱스로, 고유성을 보장합니다.
2. $arrSort가 정렬됩니다.
3 $arrSort를 탐색하여 해당 인덱스에 따라 다차원 배열의 데이터를 얻고, 정렬된 다차원 배열을 재구성합니다.
코드 복사 코드는 다음과 같습니다.
배열
(
[0] => 배열
(
[링크] => 테스트
[이름] => ; test.rpm
[유형] => 파일
[크기] => 988.9k
[mtime] => 1185160178)
....
)
코드 복사 코드는 다음과 같습니다.
_array_sort($arrFile, 1, 1);//이름 필드에 따라 정렬
_array_sort( $arrFile, 3, 1);//크기에 따라 정렬 필드
/*
@records 정렬할 배열
@field 정렬할 필드, 숫자인지 주의하세요
@역순 또는 역순
*/
function _array_sort($records, $field, $reverse, $ defaultSortField = 0)
{
$uniqueSortId = 0
$hash = array();
$sortedRecords = array();
$ indexedArray = array()
foreach($ $record로 기록)
{
$uniqueSortId;
$recordStr = implode("|", $ Record)."|".$uniqueSortId;
$recordArray[] =explore("| ", $recordStr);
}
$primarySortIndex = count($record);
$records = $recordArray;
foreach($records as $record)
{
$ hash[$record[$primarySortIndex]] = $record[$field];
}
uasort($hash , "strnatcasecmp")
if($reverse)
$hash = array_reverse( $hash, true);
$valueCount = array_count_values($hash);
foreach($hash as $primaryKey => $value)
{
$indexedArray[] = $primaryKey; 🎜>}
$i = 0;
foreach($hash as $primaryKey => $value)
{
$i
if($valueCount[$value] > 1)
{
foreach($records를 $record로)
{
if($primaryKey == $record[$primarySortIndex])
{
$tempArr[$record[ $defaultSortField]."__".$i] = $record;
}
}
$index = array_search($primaryKey, $indexedArray)
if(($ i == count($records)) || ($value != $hash[$indexedArray[$index 1]]) )
{
uksort($tempArr, "strnatcasecmp")
if ($reverse)
$tempArr = array_reverse($tempArr);
foreach($tempArr as $newRecs)
{
$sortedRecords [] = $newRecs; tempArr = array()
}
}
else
{
foreach($ 레코드를 $record로 저장)
{
if($primaryKey == $record[$ PrimarySortIndex])
{
$sortedRecords[] = $record;
break;
}
}
}
}
return $sortedRecords;
II array_map 및 array_mutisor를 사용하여 정렬
array_mutisor는 여러 값을 기반으로 수행할 수도 있습니다. 2차 또는 3중 정렬은 이전 기능과 비교할 수 없습니다.
코드 복사
array_map 사용 정렬할 배열 가져오기$arrField = array_map(create_function('$n', 'return $ n["size"];'), $arrFile) //array_mutisort를 사용하여 정렬$array_multisort($arrField, SORT_DESC, $arrFile)
III 최종 테스트
188개의 데이터 배열로 테스트하고 50번 정렬하여 평균을 구합니다.
첫 번째 유형 방법
0.04269016 이름
0.04267142 크기
두 번째 방법