首頁 >後端開發 >php教程 >PHP array_multisort()函數的使用紮記

PHP array_multisort()函數的使用紮記

高洛峰
高洛峰原創
2017-01-06 16:55:301252瀏覽

函數bool array_multisort ( array &$arr [, mixed $arg = SORT_ASC [, mixed $arg = SORT_REGULAR [, mixed $...]]] ) 
參數說明: 函數對多個陣列或多維陣列進行排序一個參數是數組,隨後的每一個參數可能是數組,也可能是下面的排序順序標誌 
SORT_ASC - 默認,按升序排列 
SORT_DESC - 按降序排列 
隨後可以指定排序的類型 
SORT_REGULAR - 預設。將每一項按常規順序排列。 
SORT_NUMERIC - 將每一項依數字順序排列。 
SORT_STRING - 將每一項按字母順序排列。
實例碼 

$arr1 = array('10', 11, 100, 100, 'a'); 
$arr2 = array(1, 2, 3, '2', 5); 
array_multisort($arr1, $arr2);

結果為: 

$arr1 
Array ( [0] => 10 [1] => a [2] => 11 [3] => 100 [4] => 100 ) 
'10 '與11, 100, 100比較時轉換為整數10,小於其他三個數 
# '10'在於'a'比較時作為字串,其第一個字元'1'ascii碼值為49小於' a'(ascii值為97),所以'10'為最小元素 
# 'a'在於其他三個數字比較時,轉換為整數0,小於其他三個數 
$arr2 
Array ( [0] => 1 [1] => 5 [2] => 2 [3] => 2 [4] => 3 ) 
# $arr2元素1與$arr1元素'10'位置對應,所以排在[0]位置 
# $arr1[2] => 100, $arr1[3] => 100分別對應$arr2元素3, '2'。 3大於'2',所以與2對應的$arr1[2] => 100排序後的下標為 
3,與3對應的$arr1[3] => 100排序的下標為4 
總結 
1 .參與排序的陣列元素數保持一致 
2.排序數組元素位置對應如, '10' => 1 , 11 => 2 
3.後邊的數組在前邊數組的順序的基礎上進行排序 
4.前邊的陣列如遇相等的元素則比較後邊的陣列

array_multisort — 對多個陣列或多維陣列進行排序 

說明 
bool array_multisort ( array $ar1 [, mixed $
bool array_multisort ( array $ar1 [, mixed $... [argy $... $... ]]] ) 
成功時回傳TRUE, 或失敗時回傳FALSE. 

array_multisort() 可以用來一次對多個陣列進行排序,或是依照某一維或多維度對多維數組進行排序。 

關聯(string)鍵名不變,但數字鍵名會被重新索引。 

輸入陣列被當作一個表格的欄位並且以行來排序-這類似於 SQL 的 ORDER BY 子句的功能。第一個陣列是要排序的主要陣列。數組中的行(值)比較為相同的話就按照下一個輸入數組中對應值的大小來排序,依此類推。 

本函數的參數結構有些不尋常,但是非常靈活。第一個參數必須是一個陣列。接下來的每個參數可以是陣列或是下面列出的排序標誌。

排序順序標誌: 

SORT_ASC - 按照上升順序排序 
SORT_DESC - 按照下降順序排序 

排序類型標誌: 

SORT_REGULAR - 將項目按照通常方法比較 
SORT_NUMERIC - 將項目按照數值比較 
SORT_STRING - 將項目依字串比較 

每個陣列之後不能指定兩個同類的排序標誌。每個數組後指定的排序標誌僅對該數組有效 - 在此之前為預設值 SORT_ASC 和 SORT_REGULAR。 

#1 將多個陣列排序 

<?php 
$ar1 = array("10", 100, 100, "a"); 
$ar2 = array(1, 3, "2", 1); 
array_multisort($ar1, $ar2); 
var_dump($ar1); 
var_dump($ar2); 
?>

本例中經過排序後,第一個陣列將包含 "10","a",100,100。第二個數組將包含 1,1,"2",3。第二個陣列中的項目順序完全和第一個陣列中對應的項目(100 和 100)順序一致。

array(4) { 
[0]=> string(2) "10" 
[1]=> string(1) "a" 
[2]=> int(100) 
[3]=> int(100) 
} 
array(4) { 
[0]=> int(1) 
[1]=> int(1) 
[2]=> string(1) "2" 
[3]=> int(3) 
}

#2 對多維數組排序 

<?php 
$ar = array (array ("10", 100, 100, "a"), array (1, 3, "2", 1)); 
array_multisort ($ar[0], SORT_ASC, SORT_STRING, 
$ar[1], SORT_NUMERIC, SORT_DESC); 
?>

本例中經過排序後,第一個數組將包含10,100,100,"a"(作為字串上升排序),第二個數組將包含1, 3,"2",1(以數值下降排序)。 

#3 Sorting multi-dimensional array 

<?php 
$ar = array( 
array("10", 11, 100, 100, "a"), 
array( 1, 2, "2", 3, 1) 
); 
array_multisort($ar[0], SORT_ASC, SORT_STRING, 
$ar[1], SORT_NUMERIC, SORT_DESC); 
var_dump($ar); 
?>

本例中在排序後,第一個陣列將變成 "10",100,100,11,"a"(被當作字串以升序排列)。第二個陣列將包含 1, 3, "2", 2, 1(當作數字以降序排列)。 

array(2) { 
[0]=> array(5) { 
[0]=> string(2) "10" 
[1]=> int(100) 
[2]=> int(100) 
[3]=> int(11) 
[4]=> string(1) "a" 
} 
[1]=> array(5) { 
[0]=> int(1) 
[1]=> int(3) 
[2]=> string(1) "2" 
[3]=> int(2) 
[4]=> int(1) 
} 
}

#4 对数据库结果进行排序 
本例中 data 数组中的每个单元表示一个表中的一行。这是典型的数据库记录的数据集合。 

例子中的数据如下: 

volume | edition 
-------+-------- 
67 | 2 
86 | 1 
85 | 6 
98 | 2 
86 | 6 
67 | 7 

数据全都存放在名为 data 的数组中。这通常是通过循环从数据库取得的结果,例如 mysql_fetch_assoc()。 

6bfac01835ebc2082899a02991ee720f 67, 'edition' => 2); 
$data[] = array('volume' => 86, 'edition' => 1); 
$data[] = array('volume' => 85, 'edition' => 6); 
$data[] = array('volume' => 98, 'edition' => 2); 
$data[] = array('volume' => 86, 'edition' => 6); 
$data[] = array('volume' => 67, 'edition' => 7); 
?> 
本例中将把 volume 降序排列,把 edition 升序排列。 

现在有了包含有行的数组,但是 array_multisort() 需要一个包含列的数组,因此用以下代码来取得列,然后排序。 

1e59e18f09b8be1c5b40ba337a1ffdae $row) { 
$volume[$key] = $row['volume']; 
$edition[$key] = $row['edition']; 


// 将数据根据 volume 降序排列,根据 edition 升序排列 
// 把 $data 作为最后一个参数,以通用键排序 
array_multisort($volume, SORT_DESC, $edition, SORT_ASC, $data); 
?> 
数据集合现在排好序了,结果如下: 

volume | edition 
-------+-------- 
98 | 2 
86 | 1 
86 | 6 
85 | 6 
67 | 2 
67 | 7 


Example #5 不区分大小写字母排序 

SORT_STRING 和 SORT_REGULAR 都是区分大小写字母的,大写字母会排在小写字母之前。 

要进行不区分大小写的排序,就要按照原数组的小写字母拷贝来排序。 

<?php 
$array = array(&#39;Alpha&#39;, &#39;atomic&#39;, &#39;Beta&#39;, &#39;bank&#39;); 
$array_lowercase = array_map(&#39;strtolower&#39;, $array); 

array_multisort($array_lowercase, SORT_ASC, SORT_STRING, $array); 

print_r($array); 
?>

以上例程会输出: 

Array 

[0] => Alpha 
[1] => atomic 
[2] => bank 
[3] => Beta 


【译者注】本函数相当有用,为有助于理解,请再看下面这个例子: 


Example #6 名次排列 

<?php 
$grade = array("score" => array(70, 95, 70.0, 60, "70"), 
"name" => array("Zhang San", "Li Si", "Wang Wu", 
"Zhao Liu", "Liu Qi")); 
array_multisort($grade["score"], SORT_NUMERIC, SORT_DESC, 
// 将分数作为数值,由高到低排序 
$grade["name"], SORT_STRING, SORT_ASC); 
// 将名字作为字符串,由小到大排序 
var_dump($grade); 
?>

以上例程会输出: 

array(2) { 
["score"]=> 
array(5) { 
[0]=> 
int(95) 
[1]=> 
string(2) "70" 
[2]=> 
float(70) 
[3]=> 
int(70) 
[4]=> 
int(60) 

["name"]=> 
array(5) { 
[0]=> 
string(5) "Li Si" 
[1]=> 
string(6) "Liu Qi" 
[2]=> 
string(7) "Wang Wu" 
[3]=> 
string(9) "Zhang San" 
[4]=> 
string(8) "Zhao Liu" 


本例中对包含成绩的数组 $grade 按照分数(score)由高到低进行排序,分数相同的人则按照名字(name)由小到大排序。排序后李四 95 分为第一名,赵六 60 分为第五名没有异议。张三、王五和刘七都是 70 分,他们的名次则由其姓名的字母顺序排列,Liu 在前,Wang 在后而 Zhang 在最后。为了区别,三个 70 分分别用了整数,浮点数和字符串来表示,可以在程序输出中清楚地看到它们排序的结果。

更多PHP array_multisort()函数的使用札记相关文章请关注PHP中文网!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn