i漂泊

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 3910|回复: 0

array_multisort实现PHP多维数组排序示例讲解

[复制链接]
TA的礼物信息
  • 收到:0
  • 送出:2
发表于 2014-7-14 13:12:57 | 显示全部楼层 |阅读模式
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. 对多个数组排序
  1. <?php
  2. $ar1 = array(“10″, 100, 100, “a”);
  3. $ar2 = array(1, 3, “2″, 1);
  4. array_multisort($ar1, $ar2);

  5. var_dump($ar1);
  6. var_dump($ar2);
  7. ?>
复制代码
本例中经过排序后,第一个数组将包含 “10″,”a”,100,100。第二个数组将包含 1,1,”2″,3。第二个数组中的项目顺序完全和第一个数组中相应的项目(100 和 100)顺序一致。
  1. <blockquote>array(4) {
复制代码
例子 2. 对多维数组排序
  1. <?php
  2. $ar = array (array (“10″, 100, 100, “a”), array (1, 3, “2″, 1));
  3. array_multisort ($ar[0], SORT_ASC, SORT_STRING,
  4. $ar[1], SORT_NUMERIC, SORT_DESC);
  5. ?>
复制代码
本例中经过排序后,第一个数组将包含 10,100,100,”a”(作为字符串上升排序),第二个数组将包含 1,3,”2″,1(作为数值下降排序)。

例子 3. Sorting multi-dimensional array
  1. <?php

  2. $ar = array(
  3.     array(“10″, 11, 100, 100, “ a”),
  4.     array(1, 2, “ 2″, 3, 1)
  5. );
  6. array_multisort($ar[0], SORT_ASC, SORT_STRING, $ar[1], SORT_NUMERIC, SORT_DESC);
  7. var_dump($ar);
  8. ?>
复制代码
本例中在排序后,第一个数组将变成 “10″,100,100,11,”a”(被当作字符串以升序排列)。第二个数组将包含 1, 3, “2″, 2, 1(被当作数字以降序排列)。
  1. array(2) {
  2.     [0] => array(5) {
  3.         [0] => string(2) “10″
  4.         [1] => int(100)
  5.         [2] => int(100)
  6.         [3] => int(11)
  7.         [4] => string(1) “a”
  8.     }
  9.     [1] => array(5) {
  10.         [0] => int(1)
  11.         [1] => int(3)
  12.         [2] => string(1) “2″
  13.         [3] => int(2)
  14.         [4] => int(1)
  15.     }
  16. }
复制代码
例子 4. 对数据库结果进行排序

本例中 data 数组中的每个单元表示一个表中的一行。这是典型的数据库记录的数据集合。

例子中的数据如下:

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

数据全都存放在名为 data 的数组中。这通常是通过循环从数据库取得的结果,例如 mysql_fetch_assoc()。
  1. <?php
  2. $data[] = array(‘volume' => 67, ‘edition' => 2);
  3. $data[] = array(‘volume' => 86, ‘edition' => 1);
  4. $data[] = array(‘volume' => 85, ‘edition' => 6);
  5. $data[] = array(‘volume' => 98, ‘edition' => 2);
  6. $data[] = array(‘volume' => 86, ‘edition' => 6);
  7. $data[] = array(‘volume' => 67, ‘edition' => 7);
  8. ?>
复制代码
本例中将把 volume 降序排列,把 edition 升序排列。

现在有了包含有行的数组,但是 array_multisort() 需要一个包含列的数组,因此用以下代码来取得列,然后排序。
  1. <?php
  2. // 取得列的列表
  3. foreach ($data as $key => $row) {
  4. $volume[$key] = $row['volume'];
  5. $edition[$key] = $row['edition'];
  6. }

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

volume | edition
——-+——–
98 | 2
86 | 1
86 | 6
85 | 6
67 | 2
67 | 7
例子 5. 不区分大小写字母排序

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

要进行不区分大小写的排序,就要按照原数组的小写字母拷贝来排序。
  1. <?php
  2. $array = array(‘Alpha', ‘atomic', ‘Beta', ‘bank');
  3. $array_lowercase = array_map('strtolower', $array);

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

  5. print_r($array);
  6. ?>
复制代码
上例将输出:
  1. Array
  2. (
  3. [0] => Alpha
  4. [1] => atomic
  5. [2] => bank
  6. [3] => Beta
  7. )
复制代码
【译者注】本函数相当有用,为有助于理解,请再看下面这个例子:

例子 6. 名次排列
  1. <?php
  2. $grade = array(“score” => array(70, 95, 70.0, 60, “70″),
  3. “name” => array(“Zhang San”, “Li Si”, “Wang Wu”,
  4. “Zhao Liu”, “Liu Qi”));
  5. array_multisort($grade["score"], SORT_NUMERIC, SORT_DESC,
  6. // 将分数作为数值,由高到低排序
  7. $grade["name"], SORT_STRING, SORT_ASC);
  8. // 将名字作为字符串,由小到大排序
  9. var_dump($grade);
  10. ?>
复制代码
上例将输出:
  1. array(2) {
  2.     ["score"] =>
  3.     array(5) {
  4.         [0] =>
  5.         int(95)
  6.         [1] =>
  7.         string(2) “70″
  8.         [2] =>
  9.         float(70)
  10.         [3] =>
  11.         int(70)
  12.         [4] =>
  13.         int(60)
  14.     }
  15.     ["name"] =>
  16.     array(5) {
  17.         [0] =>
  18.         string(5) “Li Si”
  19.         [1] =>
  20.         string(6) “Liu Qi”
  21.         [2] =>
  22.         string(7) “Wang Wu”
  23.         [3] =>
  24.         string(9) “Zhang San”
  25.         [4] =>
  26.         string(8) “Zhao Liu”
  27.     }
  28. }
复制代码
本例中对包含成绩的数组 $grade 按照分数(score)由高到低进行排序,分数相同的人则按照名字(name)由小到大排序。排序后李四 95 分为第一名,赵六 60 分为第五名没有异议。张三、王五和刘七都是 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排序。它的输出结果如下:

  1. Array ([0] => Array
  2. (
  3. [id] => 2
  4. [name] => Take That
  5. [rating] => 1
  6. ) [1] => Array
  7. (
  8. [id] => 1
  9. [name] => Boney M
  10. [rating] => 3
  11. )
  12. [2] => Array
  13. (
  14. [id] => 4
  15. [name] => Lusain
  16. [rating] => 3
  17. )
  18. [3] => Array
  19. (
  20. [id] => 3
  21. [name] => The Killers
  22. [rating] => 4
  23. )
  24. )
复制代码
PHP函数array_multisort()是PHP中最有用的函数之一,它有非常广泛的应用范围。另外,就如你在例子中所看到的,它能对多个不相关的数组进行排序,也可以使用其中的一个元素作为下次排序的基础,还可以对数据库结果集进行排序。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|IPiaoBo Inc. ( 渝ICP备17002826号 )

GMT+8, 2024-5-5 13:35 , Processed in 0.073458 second(s), 43 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表