array_multisort — 对多个数组或多维数组进行排序
说明bool array_multisort ( array ar1 [, mixed arg [, mixed ... [, array ...]]] )
如果成功则返回 TRUE,失败则返回 FALSE。
array_multisort() 可以用来一次对多个数组进行排序,或者根据某一维或多维对多维数组进行排序。关联(string)键名保持不变,但数字键名会被重新索引。
输入数组被当成一个表的列并以行来排序――这类似于 SQL 的 ORDER BY 子句的功能。
第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话就按照下一个输入数组中相应值的大小来排序,依此类推。
本函数的参数结构有些不同寻常,但是非常灵活。第一个参数必须是一个数组。接下来的每个参数可以是数组或者是下面列出的排序标志。
排序顺序标志:
SORT_ASC – 按照上升顺序排序SORT_DESC – 按照下降顺序排序排序类型标志:
SORT_STRING 和 SORT_REGULAR 都是区分大小写字母的,大写字母会排在小写字母之前。
每个数组之后不能指定两个同类的排序标志。每个数组后指定的排序标志仅对该数组有效 – 在此之前为默认值 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);?>
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)}
<?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);?>
例 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);?>
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
<?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 作为最后一个参数,以通用键排序 www.it165.netarray_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"}}
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。
新闻热点
疑难解答