当前位置:首页 » 编程语言 » php多维数组数组排序

php多维数组数组排序

发布时间: 2025-07-16 04:45:19

1. array_multisort定义和用法

array_multisort函数是php中用于对数组进行多维排序的内置函数。其主要定义和用法如下:

  • 主要用途:根据提供的参数对一个或多个数组进行排序。

  • 必填参数

    • array1:需要进行排序的原始数组。
  • 可选参数

    • 排序顺序:通过该参数设定排序顺序。默认值是SORT_ASC,表示升序排列。如果需要降序排列,可以设置为SORT_DESC。
    • 排序类型:由该参数定义排序类型,可以是SORT_REGULAR,SORT_NUMERIC,或者SORT_STRING。这个参数允许根据数组元素的内在性质来定制排序规则。
    • 多个数组:除了array1,还可以传入多个可选的数组,这些数组也会根据提供的排序规则进行相应的排序。
  • 功能特点

    • 灵活性:array_multisort函数提供了灵活的方式来对数组进行复杂的排序操作。
    • 多维排序:可以对多个数组或多维数组进行排序,类似于SQL的ORDER BY子句的功能。如果数组中的行比较为相同,就会按照下一个输入数组中相应值的大小进行排序,依此类推。
  • 适用场景:适用于多种不同的数据处理场景,可根据需求调整排序顺序和类型。

2. PHP多维数组排序,用array_multisort函数对数组按指定字段排序

在PHP中,有多种函数可用于对数组进行排序。例如,sort()函数用于数组的升序排列,而rsort()则用于降序排列。asort()和arsort()分别用于根据关联数组的值进行升序和降序排列,而ksort()和krsort()则是根据键进行排序。

例如:

可以得到以下排序结果:

但是,当需要对具有多个字段的数组进行排序时,如何按照指定字段进行排序呢?以下是一个示例数组:

我们如何根据age或name进行排序呢?这时,可以使用array_multisort()函数来实现按指定字段排序。

打印结果:

这样就完成了排序。也就是说,在使用array_multisort()函数进行排序时,需要将数组指定的列提取出来作为第一个参数,排序常量作为第二个参数,原数组作为第三个参数。其中,SORT_ASC代表升序,SORT_DESC代表降序。以上就是按字段进行排序的方法,感谢大家的阅读。

3. 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
)

)

4. php 多维数组键值重新排序

$a = array(2=>array(1,2,3,4),6=>array(6,2,3,5),1=>array(1,4,53));
$b = array_values($a);//返回数基念组中的所有值,形成笑锋陵新的数组碰戚,建立数字索引

5. PHP使用array_multisort对多个数组或多维数组进行排序

PHP中array_multisort可以用来一次对多个数组进行排序,或者根据某一维或多维对多维数组进行排序。
关联(string)键名保持不变,但数字键名会被重新索引。
输入数组被当成一个表的列并以行来排序——这类似于
SQL

ORDER
BY
子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话就按照下一个输入数组中相应值的大小来排序,依此类推。——这句话是理解此函数用法的关键。
第一个参数必须是一个数组。接下来的每个参数可以是数组或者是下面列出的排序标志。
排序顺序标志:
■SORT_ASC
-
按照上升顺序排序
■SORT_DESC
-
按照下降顺序排序
排序类型标志:
■SORT_REGULAR
-
将项目按照通常方法比较
■SORT_NUMERIC
-
将项目按照数值比较
■SORT_STRING
-
将项目按照字符串比较
每个数组之后不能指定两个同类的排序标志。每个数组后指定的排序标志仅对该数组有效
-
在此之前为默认值
SORT_ASC

SORT_REGULAR。
看看两个实际例子:
1、一次对多个数组进行排序:
复制代码
代码如下:
$num1
=
array(3,
5,
4,
3);
$num2
=
array(27,
50,
44,
78);
array_multisort($num1,
SORT_ASC,
$num2,
SORT_DESC);

print_r($num1);
print_r($num2);
//result:
Array
(
[0]
=>
3
[1]
=>
3
[2]
=>
4
[3]
=>
5
)
Array
(
[0]
=>
78
[1]
=>
27
[2]
=>
44
[3]
=>
50
)
2、对多维数组(以二位数组为例)进行排序:
复制代码
代码如下:
$arr
=
array(

'0'
=>
array(

'num1'
=>
3,

'num2'
=>
27

),

'1'
=>
array(

'num1'
=>
5,

'num2'
=>
50

),

'2'
=>
array(

'num1'
=>
4,

'num2'
=>
44

),

'3'
=>
array(

'num1'
=>
3,

'num2'
=>
78

)
);
foreach
(
$arr
as
$key
=>
$row
){

$num1[$key]
=
$row
['num1'];

$num2[$key]
=
$row
['num2'];
}
array_multisort($num1,
SORT_ASC,
$num2,
SORT_DESC,
$arr);
print_r($arr);
//result:Array([0]=>Array([num1]=>3
[num2]=>78)
[1]=>Array([num1]=>3
[num2]=>27)
[2]=>Array([num1]=>4
[num2]=>44)
[3]=>Array([num1]=>5
[num2]=>50))
总结:
这里的重点就是,先把要排序的key存到一个一维数组中,然后就可以使用array_multisort()这个函数,将数组按照key进行排序了,当然,这里的排序你完全可以不适用array_multisort()这个函数,仅仅通过foreach遍历也能达到这个效果,但是既然php开发者给我们提供了更好的办法,我们就可以省去不必要的麻烦了。

6. PHP数组排序 array_multisort函数详细用法跟排序方法

一、先看最简单的情况。有两个数组:

$arr1 = array(1,9,5);
$arr2 = array(6,2,4);

array_multisort($arr1,$arr2);

print_r($arr1); // 得到的顺序是1,5,9
print_r($arr2); // 得到的顺序是6,4,2

我估计两个数组的值自始至终都是对应着的:1对应6,9对应2,5对应4。

我们再加多一个数组看看会怎样:

$arr1 = array(1,9,5);
$arr2 = array(6,2,4);
$arr3 = array(3,7,8);

array_multisort($arr1,$arr2,$arr3);

查看结果,1自始至终都对应6对应3,其它项也是如此。这种对应关系就是手册中所谓的“排序时保留原有的键名关联”。

另外也可以把每个数组想象成数据库表的一列。而对应着的1,6,3为一数据行,9,2,7为另一数据行。。。

array_multisort会先按第一个数组(想象成列)排序,如果第一个数组(列)的值相同,则按第二个数组(列)排序。

具体可以用下面的程式来测试:

$arr1 = array(1,9,5,9);
$arr2 = array(6,2,4,1);
$arr3 = array(3,7,8,0);

array_multisort($arr1,$arr2,$arr3);

可以想象这里$arr3的结果是(3,8,0,7)。

二、接下来讲解array_multisort的参数。这个函数的参数很灵活。最简单的情况是如上面所示的以1个或n个数组作为参数,需要注意的是每个数组的项数要一样,否则会warning导致排序失效。

像这样array_multisort($arr1,$arr2,$arr3); 默认是所有数组都是升序排列,如果想对$arr2降序,并当作字符串去比较,就要写成:

array_multisort($arr1, $arr2, SORT_DESC, SORT_STRING, $arr3);

每个array后面可以跟一个排序顺序标志或一个排序类型标志,或者两种标志同时出现。但是每种排序标志在每个数组后面只能出现一个。

详细如下:

排序顺序标志:

SORT_ASC - 按照上升顺序排序(默认)

SORT_DESC - 按照下降顺序排序

排序类型标志:

SORT_REGULAR - 将项目按照通常方法比较(默认)

SORT_NUMERIC - 将项目按照数值比较

SORT_STRING - 将项目按照字符串比较

三、最后是array_multisort有什么实际作用。

我们通常有一些多维数组需要排序:

$guys = Array
(
[0] => Array
(
[name] => jake
[score] => 80
[grade] => A
)

[1] => Array
(
[name] => jin
[score] => 70
[grade] => A
)

[2] => Array
(
[name] => john
[score] => 80
[grade] => A
)

[3] => Array
(
[name] => ben
[score] => 20
[grade] => B
)

)
例如我们想按成绩倒序排列,如果成绩相同就按名字的升序排列。
这时我们就需要根据$guys的顺序多弄两个数组出来:
$scores = array(80,70,80,20);
$names = array('jake','jin','john','ben');
然后
array_multisort($scores, SORT_DESC, $names, $guys);就行了
还能不能更灵活一点呢,每次想排序都要另外弄些数组出来吗?
其实在qeephp的helper_array类里面已经封装得很好,下面是它的两个方法,需要的人自己修改一下就可以用了:
/**
* 根据指定的键对数组排序
*
* 用法:
* @code php
* $rows = array(
* array('id' => 1, 'value' => '1-1', 'parent' => 1),
* array('id' => 2, 'value' => '2-1', 'parent' => 1),
* array('id' => 3, 'value' => '3-1', 'parent' => 1),
* array('id' => 4, 'value' => '4-1', 'parent' => 2),
* array('id' => 5, 'value' => '5-1', 'parent' => 2),
* array('id' => 6, 'value' => '6-1', 'parent' => 3),
* );
*
* $rows = Helper_Array::sortByCol($rows, 'id', SORT_DESC);
* mp($rows);
* // 输出结果为:
* // array(
* // array('id' => 6, 'value' => '6-1', 'parent' => 3),
* // array('id' => 5, 'value' => '5-1', 'parent' => 2),
* // array('id' => 4, 'value' => '4-1', 'parent' => 2),
* // array('id' => 3, 'value' => '3-1', 'parent' => 1),
* // array('id' => 2, 'value' => '2-1', 'parent' => 1),
* // array('id' => 1, 'value' => '1-1', 'parent' => 1),
* // )
* @endcode
*
* @param array $array 要排序的数组
* @param string $keyname 排序的键
* @param int $dir 排序方向
*
* @return array 排序后的数组
*/
static function sortByCol($array, $keyname, $dir = SORT_ASC)
{
return self::sortByMultiCols($array, array($keyname => $dir));
}
/**
* 将一个二维数组按照多个列进行排序,类似 SQL 语句中的 ORDER BY
*
* 用法:
* @code php
* $rows = Helper_Array::sortByMultiCols($rows, array(
* 'parent' => SORT_ASC,
* 'name' => SORT_DESC,
* ));
* @endcode
*
* @param array $rowset 要排序的数组
* @param array $args 排序的键
*
* @return array 排序后的数组
*/
static function sortByMultiCols($rowset, $args)
{
$sortArray = array();
$sortRule = '';
foreach ($args as $sortField => $sortDir)
{
foreach ($rowset as $offset => $row)
{
$sortArray[$sortField][$offset] = $row[$sortField];
}
$sortRule .= '$sortArray[\'' . $sortField . '\'], ' . $sortDir . ', ';
}
if (empty($sortArray) || empty($sortRule)) { return $rowset; }
eval('array_multisort(' . $sortRule . '$rowset);');
return $rowset;
}

7. 关于PHP中array_multisort函数的问题

仔细看API:http://www.w3school.com.cn/php/func_array_multisort.asp

热点内容
linuxwin7共享 发布:2025-07-16 12:26:21 浏览:324
vpn搭建linux 发布:2025-07-16 11:55:37 浏览:520
建模编程待遇 发布:2025-07-16 11:49:51 浏览:634
虚拟服务器如何开店 发布:2025-07-16 11:32:28 浏览:298
C语言考过 发布:2025-07-16 11:32:17 浏览:89
linux桌面系统排名 发布:2025-07-16 11:29:14 浏览:777
编译桌面布局 发布:2025-07-16 11:22:48 浏览:857
mc怎么免费开服务器网易版 发布:2025-07-16 11:22:36 浏览:272
php字符串数组替换 发布:2025-07-16 11:00:08 浏览:470
java词云 发布:2025-07-16 10:56:22 浏览:633