PHP 配列関数 array_map、array_multisort 多次元配列のソート例
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-07-25 09:04:05
-
-
- array_sort($arrFile, 1, 1);//名前フィールドに従って並べ替えます
- array_sort($arrFile, 3, 1);//名前フィールドに従って並べ替えますsize field
- / *
- @records ソート対象の配列
- @field ソート対象のフィールド、数値かどうかに注意
- @逆正負の順序
- */
- function _array_sort($records, $field, $reverse , $defaultSortField = 0)
- {
- $uniqueSortId = 0;
- $sortedRecords = array();
- $indexedArray = array(); array();
foreach($records として $record)
- {
- $uniqueSortId++;
- $recordStr = implode("|", $record)."|".$uniqueSortId; $recordArray[] =explode(" |", $recordStr);
- }
$primarySortIndex = count($record);
- $records = $recordArray;
- < ;p>foreach($records as $record)
- {
- $hash[$record[$primarySortIndex]] = $record[$field];
- }
- uasort($hash, "strnatcasecmp"); )
- $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 as $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;
- }
- }
- }
- return $sortedRecords}
-
-
-
-
-
-
- 2. array_map とarray_mutisort を使用して並べ替えます。
array_mutisor は、前の関数とは比較にならない、複数の値に基づいて 2 番目または 3 番目の並べ替えを実行することもできます。
array_map を使用して並べ替える配列を取得します
$arrField = array_map(create_function('$n', 'return $n["size"];'), $arrFile);
//array_mutisort を使用して並べ替えます
$array_multisort($arrField, SORT_DESC, $arrFile);
-
- 3. 最終テスト
188 個のデータの配列を使用してテストし、50 回並べ替えて平均を見つけます。
方法 1:
0.04269016 名前
0.04267142サイズ
-
- 方法 2:
0.001249 名前
0.00083924 サイズ
-
>>> 詳細については、PHP 配列ソートメソッドの完全なリストをご覧ください
|
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
-
2024-10-22 09:46:29
-
2024-10-13 13:53:41
-
2024-10-12 12:15:51
-
2024-10-11 22:47:31
-
2024-10-11 19:36:51
-
2024-10-11 15:50:41
-
2024-10-11 15:07:41
-
2024-10-11 14:21:21
-
2024-10-11 12:59:11
-
2024-10-11 12:17:31