首頁 >後端開發 >php教程 >muv-luv(alternative) php array_map array_multisort 高效處理多維數組排序

muv-luv(alternative) php array_map array_multisort 高效處理多維數組排序

WBOY
WBOY原創
2016-07-29 08:40:02928瀏覽

對多維數組排序,通用的作法是
1 獲取利用排序的資料並且將其放入數組$arrSort. 其中鍵索引為要排序數組的索引,保證唯一性
2 利用排序函數sort等對$arrSort進行排序.
3 遍歷$arrSort, 根據其索引,獲取多維數組的數據,重新構造排序後的多維數組.

複製代碼 程式碼如下:


Array
(
[0] => Array
(
[link] => test
[名稱] => test. rpm
[type] => file
[size] => 988.9k
[mtime] => 1185160178)
....
)


I 很久以前在網路上找到的一個排序函數,談不上高效,但很實用

複製程式碼 程式碼如下:


_array_sort($arrFile, 1, 1);//依照name欄位排序
_array_sort($arrFile, 3, 1);//依照size欄位排序
/*
@records 要排序的陣列
@field要排序的欄位,注意是數字
@reverse正序還是反序
*/
function _array_sort($records, $field, $reverse, $defaultSortField = 0)
{
$uniqueSortId = 0;
$hash = array();
$sortedRecords = array();
$tempArr = array();
$indexedArray = array();
$recordArray = array();
foreach($records as $record)
{
$uniqueSortId++;
$recordStr = implode("|", $record)."|" .$uniqueSortId;
$recordArray[] = explode("|", $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 $primary =Key> $value)
foreach($hash as $primary =Key> $value)
{
$indexedArray[] = $primaryKey;
}
$i = 0;
foreach($hash as $primaryKey => $value)
{
$i++ ;
if($valueCount[$value] > 1)
{
foreach($records as $record)
{
if($primaryKey == $record[$primarySortIndex])
{
$tempArr[$record[$defaultSortField]."__".$i] = $record;
break;
}
}
$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)
{
foreach($tempArr as $newRecs)
{
$sortedRecord [] = $newRecs;
}
$tempArr = array();
}
}
else
{
foreach($records as $record)
{
foreach($records as $record)
{
foreach($records as $record)
{
foreach($records as $record)
{
if($primaryKey == $record[$primarySortIndex])
{
$sortedRecords[] = $record;

break;
}
}
}

} } } } }

}

}
}
}
}
}
}

}
}
}
}
}
}
}
}
) 🎜>}
return $sortedRecords;

}

II 用array_map和array_mutisort來排序array_mutisort也可以根據多個值來進行二次或三次排序值來進行二次或三次排序上一個函數所不能比的. 複製程式碼 程式碼如下:利用array_map來取得要依據排序的陣列利用array_map對應>$arrField = array_map(create_function('$n', 'return $n["size"];'), $arrFile); //利用array_mutisort來進行排序$array_multisort($arrField, SORT_Cield , $arrFile); III 最終檢定以188個資料的陣列進行測試, 排序50次求平均值. 第一種方式0.04269016 name 第一種方式0.04269016 name 第一種方式0.04269016 name 第一種方式0.04269016 name 0.04267142 size 第二種方式0.001249 name 0.00083924 size 結果不言而喻 以上就介紹了muv-luv(alternative) php array_map array_multisort 高效處理多維數組排序,包括了muv-luv(alternative)方面的內容,希望對PHP教程有興趣的朋友有所幫助。
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn