下边提到的几个数组函数的排序有一些共性: 1 数组被作为排序函数的参数,排序以后,数组本身就发生了改变,函数的返回值为bool类型。
2 函数
中出现a表示association,含义为,在按值排序的过程中,保持key=>value的对应关系不变
3 函数
中出现k表示key,含义为,在按值排序的过程中按照数组key而不是数组的值排序
4 函数中出现单r的表示reverse,含义为,按照跟不加r的相反的顺序排列
5 函数名中出现单u的表示user-defined含义为,使用用户自定义函数排序,如果函数的逻辑是参数1<参数2返回负数,则按照升序排列(p1小2返负升)。 --------------------sort函数升序排序-------------------------------- bool sort ( array &$array [, int $sort_flags= SORT_REGULAR ] ) <?php $fruits = array("lemon", "orange", "banana", "apple"); sort($fruits); var_dump($fruits); ?> 结果: array

0 => 

string

 'apple' (length=5)   1 => 

string

 'banana' (length=6)   2 => 

string

 'lemon' (length=5)   3 => 

string

 'orange' (length=6)
--------------------rsort降序排列-------------------- <?php $fruits = array("lemon", "orange", "banana", "apple"); rsort($fruits); var_dump($fruits); ?> 结果: array 0 =>

string

 'orange' (length=6)   1 => 

string

 'lemon' (length=5)   2 => 

string

 'banana' (length=6)   3 => 

string

 'apple' (length=5)
---------------asort按照二维数组值的升序排列(保持key=>value的关联关系)----------- <?php $fruits = array("d" => "lemon", "a" => "orange", "b" => "banana", "c" => "apple"); asort($fruits); var_dump($fruits); ?> 结果: array 'c' =>

string

 'apple' (length=5)   'b' => 

string

 'banana' (length=6)   'd' => 

string

 'lemon' (length=5)   'a' => 

string

 'orange' (length=6)
--------------arsort按照二维数组值的降序排列(保持key=>value的关联关系)-------------- <?php $fruits = array("d" => "lemon", "a" => "orange", "b" => "banana", "c" => "apple"); arsort($fruits); var_dump($fruits); ?> 结果 array 'a' =>

string

 'orange' (length=6)   'd' => 

string

 'lemon' (length=5)   'b' => 

string

 'banana' (length=6)   'c' => 

string

 'apple' (length=5)
--------------------ksort按照数组的key升序排列-------------- <?php

$fruits = array("d"=>"lemon", "a"=>"orange", "b"=>"banana", "c"=>"apple"); ksort($fruits); var_dump($fruits); ?> 结果 array

'a' => 

string

 'orange' (length=6)   'b' => 

string

 'banana' (length=6)   'c' => 

string

 'apple' (length=5)   'd' => 

string

 'lemon' (length=5)
---------------------krsort按照数组key的降序排列-------------------------------- <?php $fruits = array("d"=>"lemon", "a"=>"orange", "b"=>"banana", "c"=>"apple"); krsort($fruits); var_dump($fruits); ?>
array 'd' =>

string

 'lemon' (length=5)   'c' => 

string

 'apple' (length=5)   'b' => 

string

 'banana' (length=6)   'a' => 

string

 'orange' (length=6)
----------------usort函数按照用户自定义的函数排序---------------- <?php function cmp($a, $b) { if ($a == $b) { return 0; } return ($a < $b) ? -1 : 1; }
$a = array(3, 2, 5, 6, 1);
usort($a, "cmp");
var_dump($a); ?> 结果: array 0 =>

int

    1 => 

int

    2 => 

int

    3 => 

int

    4 => 

int

-----------------uksort使用自定义函数按照数组的key排序----------------- <?php function cmp($a, $b) {     $a = preg_replace('@^(a|an|the) @', '', $a);     $b = preg_replace('@^(a|an|the) @', '', $b);     return strcasecmp($a, $b); }
$a = array("John" => 1, "the Earth" => 2, "an apple" => 3, "a banana" => 4);
uksort($a, "cmp");
var_dump($a); ?> 结果: array 'an apple' =>

int

    'a banana' => 

int

    'the Earth' => 

int

    'John' => 

int

-------------------uasort将数组用自定义函数按照value排序,保持索引关系不变--------- <?php // Comparison function function cmp($a, $b) {     if ($a == $b) {         return 0;     }     return ($a < $b) ? -1 : 1; }
// Array to be sorted $array = array('a' => 4, 'b' => 8, 'c' => -1, 'd' => -9, 'e' => 2, 'f' => 5, 'g' => 3, 'h' => -4); var_dump($array);
// Sort and print the resulting array uasort($array, 'cmp'); var_dump($array); ?> 结果: array 'a' =>

int

    'b' => 

int

    'c' => 

int

 -1   'd' => 

int

 -9   'e' => 

int

    'f' => 

int

    'g' => 

int

    'h' => 

int

 -4 array   'd' => 

int

 -9   'h' => 

int

 -4   'c' => 

int

 -1   'e' => 

int

    'g' => 

int

    'a' => 

int

    'f' => 

int

    'b' => 

int

-------------------array_multisort排序多个数组或多维数组--------- <?php $ar = array(        array("10", 11, 100, 100, "a"),        array(   1,  2, "2",   3,   1)       );     array_multisort($ar[0], SORT_ASC, SORT_STRING,                 $ar[1], SORT_NUMERIC, SORT_DESC); var_dump($ar); ?> 结果: array   0 =>      array       0 => 

string

 '10' (length=2)       1 => 

int

        2 => 

int

        3 => 

int

        4 => 

string

 'a' (length=1)   1 =>      array       0 => 

int

        1 => 

int

        2 => 

string

 '2' (length=1)       3 => 

int

        4 => 

int

 //说明: 1 上例中:$ar数组优先按照$ar[0]的字符串值升序排列,如果字符串值相等,再按照$ar[1]数组的数字值降序排列。 2 array_multisort函数的任意一个位置的参数如果是数组,表示排序时用的值, 如果有多个数组参数,优先按照前边的数组值进行排序,如果是常量,例如 SORT_ASC, SORT_DESC, SORT_REGULAR,SORT_NUMERIC, SORT_STRING. 表示排序方法(数组取值前优先)。
==========================================================================================

PHP二维数组排序函数

PHP一维数组的排序可以用sort(),asort(),arsort()等函数,但是PHP二维数组的排序需要自定义。

以下函数是对一个给定的二维数组按照指定的键值进行排序,先看函数定义:

01.function array_sort($arr,$keys,$type='asc'){
02.$keysvalue = $new_array = array();
03.foreach ($arr as $k=>$v){
04.$keysvalue[$k] = $v[$keys];
05.}
06.if($type == 'asc'){
07.asort($keysvalue);
08.}else{
09.arsort($keysvalue);
10.}
11.reset($keysvalue);
12.foreach ($keysvalue as $k=>$v){
13.$new_array[$k] = $arr[$k];
14.}
15.return $new_array;
16.}

它可以对二维数组按照指定的键值进行排序,也可以指定升序或降序排序法(默认为升序),用法示例:

01.$array = array(
02.array('name'=>'手机','brand'=>'诺基亚','price'=>1050),
03.array('name'=>'笔记本电脑','brand'=>'lenovo','price'=>4300),
04.array('name'=>'剃须刀','brand'=>'飞利浦','price'=>3100),
05.array('name'=>'跑步机','brand'=>'三和松石','price'=>4900),
06.array('name'=>'手表','brand'=>'卡西欧','price'=>960),
07.array('name'=>'液晶电视','brand'=>'索尼','price'=>6299),
08.array('name'=>'激光打印机','brand'=>'惠普','price'=>1200)
09.);
10. 
11.$ShoppingList = array_sort($array,'price');
12.print_r($ShoppingList);

上面是对$array这个二维数组按照'price'从低到高的排序。

输出结果:(略)。

php数组排序函数的更多相关文章

  1. 常用的php数组排序函数

    分享几个php数组排序函数,每个函数出去sort是排序的意思前缀字母的含义分别代表: a 索引 k 数组键 r 逆向 u 用户自定义 顺序排序函数 sort — 对数组排序  ksort — 对数组按 ...

  2. PHP数组排序函数有哪些

    PHP数组排序函数有哪些 一.总结 一句话总结:其实也就是是否保持索引,对键排序还是对值排序,除了sort,rsort.shuffle,usort外,都是保持索引的 是否保持索引 键排序 值排序 除了 ...

  3. 一个不错的PHP二维数组排序函数简单易用存用

    一个不错的PHP二维数组排序函数简单易用存用 传入数组,传入排序的键,传入排序顺序 public function array_sort($arr,$keys,$type='asc') { $keys ...

  4. PHP的数组排序函数

    <?php class order{ /** * * 数组排序 * @param array $arr 例如: * array ( array ( 'deskId' => '460646' ...

  5. Js数组排序函数sort()

    JS实现多维数组和对象数组排序,用的其实就是原生sort()函数,语法为:arrayObject.sort(sortby)(sortby 可选.规定排序顺序.必须是函数.) 返回值为对数组的引用:请注 ...

  6. PHP数组排序函数array_multisort()函数详解

    这个函数因为用到了,并且在网上找了半天终于找到了一个写的通俗易懂的文章,在这里分享给大家. 原文链接:http://blog.163.com/lgh_2002/blog/static/44017526 ...

  7. PHP数组排序函数array_multisort()函数详解(二)

    array_multisort()这个函数可以对多个PHP数组进行排序,排序结果是所有的数组都按第一个数组的顺序进行排列 例如array_multisort($a,$b),$a,$b是两个数组,如果排 ...

  8. PHP的一个牛逼的数组排序函数array_multisort

    函数详情,具体可参考 官方手册 array_multisort 实际问题是这样的,有这么一组数据: $arr_times = array( array('2018-04-12 04:25:00', 3 ...

  9. JS中的数组排序函数sort()

    JavaScript实现多维数组.对象数组排序,其实用的就是原生的sort()方法,用于对数组的元素进行排序. sort() 方法用于对数组的元素进行排序.语法如下: arrayObject.sort ...

随机推荐

  1. HDU5008 Boring String Problem(后缀数组)

    练习一下字符串,做一下这道题. 首先是关于一个字符串有多少不同子串的问题,串由小到大排起序来应该是按照sa[i]的顺序排出来的产生的. 好像abbacd,排序出来的后缀是这样的 1---abbacd ...

  2. ZOJ3238 Water Ring(计算几何)

    题意:给你一个圆形和很多个矩形,然后要你求圆形的圆周有多少被矩形覆盖. 思路:比赛的时候是有思路的了,不过一直在调别的题,最后剩下30分钟肯定来不及敲.想法是这样的,要是我们可以求出每个矩形覆盖了圆周 ...

  3. Visual Studio 快捷键

    Visual Studio 快捷键 CTRL + DELETE 删除至词尾 CTRL + BACKSPACE 删除至词头Ctrl+Shift+L: 删除当前行 Ctrl+K+Crtr+C: 注释选定内 ...

  4. JAVA容器

    JAVA容器 一.容器体系结构 java.util 二.迭代器Iterator<E> 迭代器是一种设计模式,可以遍历并选择序列中的对象,而开发人员并不需要了解该序列的底层结构.迭代器通常被 ...

  5. appium自动化测试中获取toast消息的解决方法【转】

    http://blog.csdn.net/hqzxsc2006/article/details/50036911 待实践.. 解决方法:appium下切换selendroid模式去获取Android的 ...

  6. 当C++学到第20天的时候我崩溃了(找回刚开始的激情)

    首先声明,我是个使用多语言(ASM/C/C++/Java/Perl)的人,主要使用C++和Java所以我认为我的意见还算中肯.那些否定C++的人,你们是否了解————Borland鼓吹Delphi如何 ...

  7. 继电器Relay:ZZR08

    继电器常识: 继电器有三个接线柱:常开(NO),常闭(NC),接地(C) 如果连接的时间长,偶尔需要断电, 那么接NC 和 C, 这样继电器set on 时为断电.除此之外,继电器还可以控制按键,以及 ...

  8. Java-在线聊天系统-非线程

    一.概述 1.目标:建立基于tcp协议的聊天系统 2.思路:用java socket编程 二.代码 1.ChatServer.java import java.io.DataInputStream; ...

  9. 研究CPU的好文章以及博客

    留个爪,有空仔细看: http://blog.csdn.net/zhangxinrun/article/details/6918862 http://blog.csdn.net/gaijf/artic ...

  10. DXT纹理压缩

    转:http://blog.csdn.net/lhc717/article/details/6802951 我们知道游戏中对于3D物体表面细节的表现最重要的还是靠贴图来实现的,那么越是高分辨率越是真彩 ...