→相关 之前我们了解了一维数组的几种排序方法,知道PHP内置了不少函数来实现一维数组的降序排序和升序排序。那么二维数组是否也内置了函数来实现排序呢? 答案是:有的!PHP内置了 方法1:foreach循环 + array_multisort()函数 分析一下代码: 使用foreach循环将同一字段的数据放在一起,使用 使用 因此输出结果: 而如果想要根据id降序排列,只要将该函数第二个参数设置为 输出结果: 如果想要根据last_name进行排序,只要将该函数第一个参数设置为$LastName数组即可 输出结果: 下面我们来了解一下array_multisort()函数: array_multisort() 函数返回一个排序数组。用户可以输入一个或多个数组,该函数会先对第一个数组进行排序,接着是其他数组,如果两个或多个值相同,它将对下一个数组进行排序。语法如下: 方法2:array_column()函数+array_multisort()函数 在方法1中,我们是利用foreach循环来获取同一字段的数据,这有点复杂。其实,可以使用array_column()函数来实现这一操作。array_column()函数可以返回输入数组中某个单一列的值。 输出结果: 想要根据哪个字段来排序就将 输出结果: 下面我们来了解一下array_column()函数: array_column() 返回输入数组中某个单一列的值。语法格式为: 返回值:返回一个数组,数组的值为输入数组中某个单一列的值。 好了就说到这里了,有其他想知道的,可以点击这个哦。→ → 最后给大家推荐一个PHP数组的免费视频教程:,快来学习吧!
array_multisort()
函数可实现二维数组的排序。下面我们给大家介绍两种利用array_multisort()函数对二维数组进行排序的方法。<?php
$data = array(
array(
'id' => 5698,
'first_name' => 'Bill',
'last_name' => 'Gates',
),
array(
'id' => 3809,
'first_name' => 'Mark',
'last_name' => 'Zuckerberg',
),
array(
'id' => 4767,
'first_name' => 'Steve',
'last_name' => 'Aobs',
)
);
// 取得列的列表
foreach ($data as $key => $row)
{
$ID[$key] = $row['id'];
$FirstName[$key] = $row['first_name'];
$LastName[$key] = $row['last_name'];
}
array_multisort($ID, SORT_ASC, $data);
var_dump($data);
?>
var_dump($ID)
、var_dump($FirstName)
、var_dump($LastName)
输出各个字段数据试试:array_multisort($ID, SORT_ASC, $data)
根据二维数组$data中 “id
”那一列字段进行升序排序。SORT_DESC
即可:array_multisort($ID, SORT_DESC, $data);
array_multisort($LastName, SORT_DESC, $data);
array_multisort(array1,sorting order,sorting type,array2,array3...)
<?php
$data = array(
array(
'id' => 5698,
'first_name' => 'Bill',
'last_name' => 'Gates',
),
array(
'id' => 3809,
'first_name' => 'Mark',
'last_name' => 'Zuckerberg',
),
array(
'id' => 4767,
'first_name' => 'Steve',
'last_name' => 'Aobs',
)
);
//根据字段id对数组$data进行升序排列
$key = array_column($data,'id');
array_multisort($key,SORT_ASC,$data);
var_dump($data);
?>
array_column($data,'id')
函数的第二个参数换成那个字段(键值)即可。例如想要根据字段“first_name”来降序排序,则可:$key = array_column($data,'first_name');
array_multisort($key,SORT_DESC,$data);
array_column(array,column_key,index_key);