>백엔드 개발 >PHP 튜토리얼 >muv-luv(대체) php array_map array_multisort는 다차원 배열 정렬을 효율적으로 처리합니다.

muv-luv(대체) php array_map array_multisort는 다차원 배열 정렬을 효율적으로 처리합니다.

WBOY
WBOY원래의
2016-07-29 08:40:02930검색

다차원 배열을 정렬하는 일반적인 방법은
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 크기
두 번째 방법

0.001249 이름
0.00083924 크기
결과는 자명하다.
위에서는 muv-luv(alternative)의 내용을 포함하여 다차원 배열 정렬을 효율적으로 처리하기 위해 php array_map array_multisort를 도입했습니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되길 바랍니다.


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.