PHP数组函数array_multisort()用法实例分析


Posted in PHP onApril 02, 2016

本文实例分析了PHP数组函数array_multisort()用法。分享给大家供大家参考,具体如下:

有时候我们需要对二维数组的某个键的值进行排序,这里就是讨论这个问题。我们可以使用array_multisort()这个函数。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 递增。可以在每个数组后设置排序顺序和排序类型。如果没有设置,每个数组参数会使用默认值。

下面是一个例子:

<?php
 $arr = '';
 echo '二维数组如下:'.'<br / >';
 for($i=0; $i<=5; $i++)
 {
 $arr[$i]['val'] = mt_rand(1, 100);
 $arr[$i]['num'] = mt_rand(1, 100);
 }
 echo '<pre>';
 print_r($arr);
 echo '</pre>';
 echo '从二维数组中抽出键为val,单独成另一个数组:'.'<br / >';
 foreach ($arr as $key => $row) 
 {
   $vals[$key] = $row['val'];
    $nums[$key] = $row['num'];
 }
 echo '<pre>';
 print_r($vals);
 echo '</pre>';
 echo '对其进行排序:'.'<br / >';
 array_multisort($vals, SORT_ASC, $arr);
 echo '<pre>';
 print_r($vals);
 echo '</pre>';
?>

运行结果:

二维数组如下:
Array
(
  [0] => Array
    (
      [val] => 46
      [num] => 49
    )
  [1] => Array
    (
      [val] => 8
      [num] => 24
    )
  [2] => Array
    (
      [val] => 37
      [num] => 3
    )
  [3] => Array
    (
      [val] => 32
      [num] => 35
    )
  [4] => Array
    (
      [val] => 19
      [num] => 38
    )
  [5] => Array
    (
      [val] => 30
      [num] => 37
    )
)

 
从二维数组中抽出键为val,单独成另一个数组:

Array
(
  [0] => 46
  [1] => 8
  [2] => 37
  [3] => 32
  [4] => 19
  [5] => 30
)

对其进行排序:

Array
(
  [0] => 8
  [1] => 19
  [2] => 30
  [3] => 32
  [4] => 37
  [5] => 46
)

这样我们将得到一个按val升序排序的二维数组。

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
mysq GBKl乱码
Nov 28 PHP
linux php mysql数据库备份实现代码
Mar 10 PHP
php 魔术方法使用说明
Oct 20 PHP
一道求$b相对于$a的相对路径的php代码
Aug 08 PHP
应用开发中涉及到的css和php笔记分享
Aug 02 PHP
解析在PHP中使用mysqli扩展库对mysql的操作
Jul 03 PHP
让codeigniter与swfupload整合的最佳解决方案
Jun 12 PHP
PHP带节点操作的无限分类实现方法详解
Nov 09 PHP
PHP+AjaxForm异步带进度条上传文件实例代码
Aug 14 PHP
php实现session共享的实例方法
Sep 19 PHP
laravel实现于语言包的完美切换方法
Sep 29 PHP
Yii框架数据库查询、增加、删除操作示例
Oct 14 PHP
PHP使用http_build_query()构造URL字符串的方法
Apr 02 #PHP
PHP递归实现层级树状展开
Apr 01 #PHP
详解PHP的Yii框架中扩展的安装与使用
Apr 01 #PHP
PHP使用SOAP扩展实现WebService的方法
Apr 01 #PHP
PHP全局变量与超级全局变量区别分析
Apr 01 #PHP
PHP计算数组中值的和与乘积的方法(array_sum与array_product函数)
Apr 01 #PHP
PHP采用超长(超大)数字运算防止数字以科学计数法显示的方法
Apr 01 #PHP
You might like
基于文本的留言簿
2006/10/09 PHP
php 三维饼图的实现代码
2008/09/28 PHP
PHP运行模式的深入理解
2013/06/03 PHP
基于PHP5魔术常量与魔术方法的详解
2013/06/13 PHP
PHP中explode函数和split函数的区别小结
2016/08/24 PHP
详解PHP队列的实现
2019/03/14 PHP
Thinkphp5 自定义上传文件名的实现方法
2019/07/23 PHP
IE7提供XMLHttpRequest对象为兼容
2007/03/08 Javascript
Javascript中正则表达式的全局匹配模式分析
2011/04/26 Javascript
JQuery获取浏览器窗口内容部分高度的代码
2012/02/24 Javascript
jquery分页插件AmSetPager(自写)
2013/04/15 Javascript
新手学习前端之js模仿淘宝主页网站
2016/10/31 Javascript
ES6中Generator与异步操作实例分析
2017/03/31 Javascript
vue.js实现简单轮播图效果
2017/10/10 Javascript
axios+Vue实现上传文件显示进度功能
2019/04/14 Javascript
浅谈Vue使用Elementui修改默认的最快方法
2020/12/05 Vue.js
Vue 3自定义指令开发的相关总结
2021/01/29 Vue.js
python登陆asp网站页面的实现代码
2015/01/14 Python
Python导入txt数据到mysql的方法
2015/04/08 Python
python2 与python3的print区别小结
2018/01/16 Python
pandas 实现将重复表格去重,并重新转换为表格的方法
2018/04/18 Python
Python开发最牛逼的IDE——pycharm
2018/08/01 Python
matplotlib实现区域颜色填充
2019/03/18 Python
Python Django 封装分页成通用的模块详解
2019/08/21 Python
Python 70行代码实现简单算式计算器解析
2019/08/30 Python
浅谈图像处理中掩膜(mask)的意义
2020/02/19 Python
python 基于selenium实现鼠标拖拽功能
2020/12/24 Python
CSS3中的display:grid,网格布局介绍
2019/10/30 HTML / CSS
HTML5 3D衣服摇摆动画特效
2016/03/17 HTML / CSS
美国知名玩具品牌:Melissa & Doug
2016/08/16 全球购物
澳大利亚在线批发商:Simply Wholesale
2021/02/24 全球购物
求职者应聘的自我评价
2013/10/16 职场文书
团队精神的演讲稿
2014/05/14 职场文书
民主评议党员个人自我评价
2015/03/03 职场文书
体育委员竞选稿
2015/11/21 职场文书
Vue.js 带下拉选项的输入框(Textbox with Dropdown)组件
2021/04/17 Vue.js