close

今天遇到二維陣列要依照其中一項來排序的問題,查了PHP手冊sort()等的func都只能丟一維陣列,後來才發現array_multisort這個func,也把問題解決了。

故把此函式記錄一下。

--

array_multisort函数的用法

 

(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

例子 1. 对多个数组排序

<?php
$ar1 
= array("10"100100"a"
);
$ar2 = array(13"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"100100"a"), array (13"2"1
));
array_multisort ($ar[0], SORT_ASCSORT_STRING
,
                 
$ar[1], SORT_NUMERICSORT_DESC
);
?>

本例中经过排序后,第一个数组将包含 10,100,100,"a"(作为字符串上升排序),第二个数组将包含 1,3,"2",1(作为数值下降排序)。

例子 3. Sorting multi-dimensional array

<?php
$ar 
= array(
       array(
"10"11100100"a"
),
       array(   
1,  2"2",   3,   1
)
      );
array_multisort($ar[0], SORT_ASCSORT_STRING
,
                
$ar[1], SORT_NUMERICSORT_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($volumeSORT_DESC$editionSORT_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_lowercaseSORT_ASCSORT_STRING$array
);

print_r($array
);
?>

上例将输出:

Array
(
    [0] => Alpha
    [1] => atomic
    [2] => bank
    [3] => Beta
)

【译者注】本函数相当有用,为有助于理解,请再看下面这个例子:

例子 6. 名次排列

<?php
$grade 
= array("score" => array(709570.060"70"
),
               
"name" => array("Zhang San""Li Si""Wang Wu"
,
                               
"Zhao Liu""Liu Qi"
));
array_multisort($grade["score"], SORT_NUMERICSORT_DESC
,
                
// 将分数作为数值,由高到低排序
                
$grade["name"], SORT_STRINGSORT_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 分为第五名没有异议。张三、王五和刘七都是 70 分,他们的名次则由其姓名的字母顺序排列,Liu 在前,Wang 在后而 Zhang 在最后。为了区别,三个 70 分分别用了整数,浮点数和字符串来表示,可以在程序输出中清楚地看到它们排序的结果。

PS: 以上资料摘自php手册。我以前竟然没有发现这个函数,遇到多维数组排序都是自己写函数来排序的,

--

轉錄 http://www.php5.idv.tw/modules.php?mod=books&act=show&shid=44

http://blog.chinaunix.net/u/12569/showart_67529.html

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 dizzy03 的頭像
    dizzy03

    碎碎念

    dizzy03 發表在 痞客邦 留言(0) 人氣()