PHP多维数组排序:array_multisort
PHP提供了通用的多维数组排序函数,array_multisort 使用这个函数需要注意:
- 变量命名不能有重复(这个看起来很简单,很基础,不过有时候不太留意就会出大问题,PHP也不会报错,就是不管怎么设置参数排序都不生效……;引申一下,在循环中使用array_multisort,需要在每次循环结束的时候销毁一下数组以及排序字段变量)
- 对于中文字符串的排序,需要转化为GBK编码:例如
$data[] = array(‘volume’ => 67, ‘edition’ => ‘李强’ ,’name’ =>’爱新觉罗’);
$data[] = array(‘volume’ => 86, ‘edition’ => ‘习平’,’name’ =>’蜡笔小新’);
$data[] = array(‘volume’ => 85, ‘edition’ => ‘李强’,’name’ =>’方腊’);
$data[] = array(‘volume’ => 98, ‘edition’ => ‘胡涛’,’name’ =>’蜡笔小新’);
$data[] = array(‘volume’ => 86, ‘edition’ => ‘江民’,’name’ =>’蜡笔小新’);
$data[] = array(‘volume’ => 67, ‘edition’ => ‘呼啦啦’,’name’ =>’何小小’);
// Obtain a list of columns
foreach ($data as $key => $row) {
$volume[$key] = $row[‘volume’];
$edition[$key] = iconv(‘UTF-8′,’GBK’,$row[‘edition’]);//
$name[$key] = iconv(‘UTF-8′,’GBK’,$row[‘name’]);
echo $row[‘volume’].’ ‘.$row[‘edition’].’ ‘.$row[‘name’].'<br>’;
}
echo ‘<br>’;
array_multisort($name, SORT_ASC, $edition, SORT_ASC, $data);
foreach ($data as $row) {
echo $row[‘volume’].’ ‘.$row[‘edition’].’ ‘.$row[‘name’].'<br>’;
}
附PHP手册上对这个函数的介绍:
(PHP 4, PHP 5)
array_multisort — 对多个数组或多维数组进行排序
说明
bool array_multisort ( array ar1 [, mixed arg [, mixed … [, array …]]] )
如果成功则返回 TRUE,失败则返回 FALSE。
array_multisort() 可以用来一次对多个数组进行排序,或者根据某一维或多维对多维数组进行排序。
关联(string)键名保持不变,但数字键名会被重新索引。
输入数组被当成一个表的列并以行来排序――这类似于 SQL 的 ORDER BY 子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话就按照下一个输入数组中相应值的大小来排序,依此类推。
本函数的参数结构有些不同寻常,但是非常灵活。第一个参数必须是一个数组。接下来的每个参数可以是数组或者是下面列出的排序标志。
排序顺序标志:
-
SORT_ASC – 按照上升顺序排序
-
SORT_DESC – 按照下降顺序排序
排序类型标志:
-
SORT_REGULAR – 将项目按照通常方法比较
-
SORT_NUMERIC – 将项目按照数值比较
-
SORT_STRING – 将项目按照字符串比较
每个数组之后不能指定两个同类的排序标志。每个数组后指定的排序标志仅对该数组有效 – 在此之前为默认值 SORT_ASC 和 SORT_REGULAR。
本例中经过排序后,第一个数组将包含 10,100,100,"a"(作为字符串上升排序),第二个数组将包含 1,3,"2",1(作为数值下降排序)。
例子 3. Sorting multi-dimensional array
本例中在排序后,第一个数组将变成 "10",100,100,11,"a"(被当作字符串以升序排列)。第二个数组将包含 1, 3, "2", 2, 1(被当作数字以降序排列)。
|
例子 4. 对数据库结果进行排序 本例中 data 数组中的每个单元表示一个表中的一行。这是典型的数据库记录的数据集合。 例子中的数据如下:
数据全都存放在名为 data 的数组中。这通常是通过循环从数据库取得的结果,例如 mysql_fetch_assoc()。
本例中将把 volume 降序排列,把 edition 升序排列。 现在有了包含有行的数组,但是 array_multisort() 需要一个包含列的数组,因此用以下代码来取得列,然后排序。
数据集合现在排好序了,结果如下:
|
例子 5. 不区分大小写字母排序 SORT_STRING 和 SORT_REGULAR 都是区分大小写字母的,大写字母会排在小写字母之前。 要进行不区分大小写的排序,就要按照原数组的小写字母拷贝来排序。
上例将输出:
|
【译者注】本函数相当有用,为有助于理解,请再看下面这个例子:
例子 6. 名次排列
上例将输出:
本例中对包含成绩的数组 $grade 按照分数(score)由高到低进行排序,分数相同的人则按照名字(name)由小到大排序。排序后李四 95 分为第一名,赵六 60 分为第五名没有异议。张三、王五和刘七都是 70 分,他们的名次则由其姓名的字母顺序排列,Liu 在前,Wang 在后而 Zhang 在最后。为了区别,三个 70 分分别用了整数,浮点数和字符串来表示,可以在程序输出中清楚地看到它们排序的结果。 |
抱歉,暂停评论。