php排序二维数组
⑴ php 根据某个字段对二维数组这个数组排序
试编写代码如下:
<?php
$array[] = array('id'=>1,'price'=>50);
$array[] = array('id'=>2,'price'=>70);
$array[] = array('id'=>3,'price'=>30);
$array[] = array('id'=>4,'price'=>20);
foreach ($array as $key=>$value){
$id[$key] = $value['id'];
$price[$key] = $value['price'];
}
array_multisort($price,SORT_NUMERIC,SORT_DESC,$id,SORT_STRING,SORT_ASC,$array);
echo '<pre>';
print_r($array);
echo '</pre>';
?>
运行结果:
Array
(
[0] => Array
(
[id] => 2
[price] => 70
)
[1] => Array
(
[id] => 1
[price] => 50
)
[2] => Array
(
[id] => 3
[price] => 30
)
[3] => Array
(
[id] => 4
[price] => 20
)
)
⑵ php二维数组排序方法
PHP二维数组排序可以通过多种方法实现,常见的包括冒泡排序、插入排序、选择排序以及内置的数组函数如array_multisort等。此外,也可以通过使用usort等用户自定义的排序函数对关联数组的键或值进行排序。
解释如下:
冒泡排序:这是一种简单的排序算法,通过不断地比较和交换相邻元素来将最大值或最小值移动到序列的一端。对于二维数组,可以根据某一列的值进行冒泡排序。但这种方法在处理大规模数据时效率较低。
插入排序:插入排序会将数组元素逐一插入到已排序的序列中,适用于数据量不大的情况。同样地,它可以用于二维数组的单列排序。
选择排序:选择排序每次从未排序的元素中找出最小的元素,存放到已排序序列的末尾。这种方法也比较适合对二维数组的特定列进行排序。
array_multisort函数:这是PHP内置的一个函数,可以对一个或多个数组进行排序。如果应用在二维数组的排序上,可以依据数组中的特定值来排序二维数组的元素。这是一个效率较高的方法,尤其是处理复杂数据时。
使用usort函数:对于关联数组的排序,可以使用自定义的比较函数usort。通过定义比较规则,可以对数组的键或值进行排序。这种方法灵活性较高,适用于复杂数据的处理。但需要编写相应的比较逻辑,稍微复杂一些。
在PHP中进行二维数组排序时,需要根据具体需求和数据的特性选择合适的方法。对于大规模数据和高性能要求的情况,通常会倾向于使用内置的array_multisort函数或其他优化过的算法。而对于小规模数据或特定需求的排序,其他方法也可以满足需求。
⑶ php 二维数组的排序问题
对二维数组排序,得用到array_multisort()
下面是从php手册摘出来的例子.具体请根据你的问题查阅手册.
=========
数据全都存放在名为 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($volume, SORT_DESC, $edition, SORT_ASC, $data);
?>
数据集合现在排好序了,结果如下:
volume | edition
-------+--------
98 | 2
86 | 1
86 | 6
85 | 6
67 | 2
67 | 7