标签:
array_multisort() 函数对多个数组或多维数组进行排序。
参数中的数组被当成一个表的列并以行来进行排序 - 这类似 SQL 的 ORDER BY 子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话,就会按照下一个输入数组中相应值的大小进行排序,依此类推。
第一个参数是数组,随后的每一个参数可能是数组,也可能是下面的排序顺序标志(排序标志用于更改默认的排列顺序)之一:
随后可以指定排序的类型:
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 递增。
注释:您可以在每个数组后设置排序顺序和排序类型。如果没有设置,每个数组参数会使用默认值。
实例:
要将age提取出来存储到一维数组里,然后按照age升序排列。
要将name提取出来存储到一维数组里,然后按照name升序排列。
<?php $users = array( array('name' => 'tom', 'age' => 20) , array('name' => 'anny', 'age' => 18) , array('name' => 'jack', 'age' => 22) ,array('name' => 'bnny', 'age' => 18) ); $ages = array(); foreach ($users as $user) { $ages[] = $user['age']; } $names=array(); foreach ($users as $user) { $names[] = $user['name']; } array_multisort($ages, SORT_ASC,$names,SORT_ASC, $users); print_r($users); ?>
标签:
原文地址:http://blog.csdn.net/czhphp/article/details/44201213