本例中经过排序后,第一个数组将包含 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, 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"
=> int(100)
=> int(100)
=> int(11)
=> string(1) "a"
}
=> array(5) {
[0]=> int(1)
=> int(3)
=> string(1) "2"
=> int(2)
=> 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
Example #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
=> atomic
=> bank
=> 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)
=>
string(2) "70"
=>
float(70)