php 方面函数之array_multisort
加入我们有这样的一个二维数组($sortArray),然后要进行排序,我们该如何处理呢
php早就为我们做好了这样方面好用的函数:array_multisort
php早就为我们做好了这样方面好用的函数:array_multisort
FIELD1 |
FIELD2 |
FIELD3 |
FIELD4 |
FIELD5 |
FIELD6 |
FIELDSORT |
FIELD8 |
FIELD9 |
1 |
*** |
*** |
*** |
*** |
*** |
3.025 |
*** |
*** |
2 |
*** |
*** |
*** |
*** |
*** |
6.756 |
*** |
*** |
3 |
*** |
*** |
*** |
*** |
*** |
5.375 |
*** |
*** |
4 |
*** |
*** |
*** |
*** |
*** |
12.645 |
*** |
*** |
5 |
*** |
*** |
*** |
*** |
*** |
-6.548 |
*** |
*** |
加入我们需要对FIELDSORT这个按从大到小的顺序排列,那我们就可以这样,先取出FIELDSORT字段的所有值,命名为$fieldInArray;
然后用array_multisort函数,进行排序处理,参考代码如下
//get fileds in array foreach($tempArray as $row) $fieldInArray[] = $row['FIELDSORT']; ..................... .......... ... ....... //sort tempArray array_multisort($fieldInArray,SORT_STRING,SORT_DESC,$tempArray);
这样以后,$tempArray的FIELDSORT的排序就是按从大到小的顺序排序了
定义和用法
array_multisort() 函数对多个数组或多维数组进行排序。
参数中的数组被当成一个表的列并以行来进行排序 - 这类似 SQL 的 ORDER BY 子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话,就会按照下一个输入数组中相应值的大小进行排序,依此类推。
第一个参数是数组,随后的每一个参数可能是数组,也可能是下面的排序顺序标志(排序标志用于更改默认的排列顺序)之一:
- SORT_ASC - 默认,按升序排列。(A-Z)
- SORT_DESC - 按降序排列。(Z-A)
随后可以指定排序的类型:
- SORT_REGULAR - 默认。将每一项按常规顺序排列。
- SORT_NUMERIC - 将每一项按数字顺序排列。
- SORT_STRING - 将每一项按字母顺序排列。
语法
array_multisort(array1,sorting order,sorting type,array2,array3...)
参数 | 描述 |
---|---|
array1 | 必需。规定输入的数组。 |
sorting order | 可选。规定排列顺序。可能的值是 SORT_ASC 和 SORT_DESC。 |
sorting type | 可选。规定排序类型。可能的值是SORT_REGULAR、SORT_NUMERIC和SORT_STRING。 |
array2 | 可选。规定输入的数组。 |
array3 | 可选。规定输入的数组。 |
提示和注释
注释:字符串键名将被保留,但是数字键将被重新索引,从 0 开始,并以 1 递增。
注释:您可以在每个数组后设置排序顺序和排序类型。如果没有设置,每个数组参数会使用默认值。
例子 1
<?php
$a1=array("Dog","Cat");
$a2=array("Fido","Missy");
array_multisort($a1,$a2);
print_r($a1);
print_r($a2);
?>
输出:
Array ( [0] => Cat [1] => Dog )
Array ( [0] => Missy [1] => Fido )
例子 2
当两个值相同时如何排序:
<?php
$a1=array("Dog","Dog","Cat");
$a2=array("Pluto","Fido","Missy");
array_multisort($a1,$a2);
print_r($a1);
print_r($a2);
?>
输出:
Array ( [0] => Cat [1] => Dog [2] => Dog )
Array ( [0] => Missy [1] => Fido [2] => Pluto )
例子 3
带有排序参数:
<?php
$a1=array("Dog","Dog","Cat");
$a2=array("Pluto","Fido","Missy");
array_multisort($a1,SORT_ASC,$a2,SORT_DESC);
print_r($a1);
print_r($a2);
?>
输出:
Array ( [0] => Cat [1] => Dog [2] => Dog )
Array ( [0] => Missy [1] => Pluto [2] => Fido )