array_multisort() 能夠用來一次對多個數組進行排序,或者根據某一維或多維對多維數組進行排序。php
array_multisort — 對多個數組或多維數組進行排序
說明
bool array_multisort ( array ar1 [, mixed arg [, mixed ... [, array ...]]] )
array_multisort
(PHP 4, PHP 5)
若是成功則返回 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()。
<?php
$data[] = array(‘volume' => 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() 須要一個包含列的數組,所以用如下代碼來取得列,而後排序。
<?php
// 取得列的列表
foreach ($data as $key => $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
例子 5. 不區分大小寫字母排序
SORT_STRING 和 SORT_REGULAR 都是區分大小寫字母的,大寫字母會排在小寫字母以前。
要進行不區分大小寫的排序,就要按照原數組的小寫字母拷貝來排序。
<?php
$array = array(‘Alpha', ‘atomic', ‘Beta', ‘bank');
$array_lowercase = array_map('strtolower', $array);
array_multisort($array_lowercase, SORT_ASC, SORT_STRING, $array);
print_r($array);
?>
上例將輸出:
Array
(
[0] => Alpha
[1] => atomic
[2] => bank
[3] => Beta
)
【譯者注】本函數至關有用,爲有助於理解,請再看下面這個例子:
例子 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 分爲第五名沒有異議。張3、王五和劉七都是 70 分,他們的名次則由其姓名的字母順序排列,Liu 在前,Wang 在後而 Zhang 在最後。爲了區別,三個 70 分分別用了整數,浮點數和字符串來表示,能夠在程序輸出中清楚地看到它們排序的結果。
補充資料:
對於PHP語言中的多維數組排序時最爲複雜的一個排序方式。咱們在實際編碼中將會用到PHP函數array_multisort()來實現這一複雜的排序。例如,首先對一個嵌套數組使用一個普通的關鍵字進行排序,而後再根據另外一個關鍵字進行排序。這與使用SQL的ORDER BY語句對多個字段進行排序很是類似。
PHP函數asort()利用值排序的具體方式解析
PHP函數arsort()的功能特色詳解
PHP天然語言排序的特色介紹
PHP天然語言倒序的具體實現方式
如何運用PHP函數usort()實現自定義排序
Listing J示例爲咱們具體說明了PHP函數array_multisort()的工做方式:
1, "name" => "Boney M", "rating" => 3), array("id" => 2, "name" => "Take That", "rating" => 1), array("id" => 3, "name" => "The Killers", "rating" => 4), array("id" => 4, "name" => "Lusain", "rating" => 3), ); foreach ($data as $key => $value) { $name[$key] = $value[name]; $rating[$key] = $value[rating]; } array_multisort($rating, $name, $data); print_r($data);?> 這裏,咱們在$data數組中模擬了一個行和列數組。而後,我使用PHP函數array_multisort()對數據集合進行重排,首先是根據rating進行排序,而後,若是rating相等的話,再根據name排序。它的輸出結果以下:
mysql
複製代碼代碼以下:sql
Array ([0] => Array
(
[id] => 2
[name] => Take That
[rating] => 1
) [1] => Array
(
[id] => 1
[name] => Boney M
[rating] => 3
)
[2] => Array
(
[id] => 4
[name] => Lusain
[rating] => 3
)
[3] => Array
(
[id] => 3
[name] => The Killers
[rating] => 4
)
)
數據庫
PHP函數array_multisort()是PHP中最有用的函數之一,它有很是普遍的應用範圍。另外,就如你在例子中所看到的,它能對多個不相關的數組進行排序,也可使用其中的一個元素做爲下次排序的基礎,還能夠對數據庫結果集進行排序。數組