PHP 二维数组根据某个字段排序

原文:PHP 二维数组根据某个字段排序

要求:从两个不同的表中获取各自的4条数据,然后整合(array_merge)成一个数组,再根据数据的创建时间降序排序取前4条。

遇到这个要求的时候就不是 ORDER BY 能解决的问题了。因此翻看 PHP 手册查找到了如下方法,做此笔记。

<?php
/**
 * 二维数组根据某个字段排序
 * 功能:按照用户的年龄倒序排序
 * @author ruxing.li
 */
header('Content-Type:text/html;Charset=utf-8');
$arrUsers = array(
    array(
            'id'   => 1,
            'name' => '张三',
            'age'  => 25,
    ),
    array(
            'id'   => 2,
            'name' => '李四',
            'age'  => 23,
    ),
    array(
            'id'   => 3,
            'name' => '王五',
            'age'  => 40,
    ),
    array(
            'id'   => 4,
            'name' => '赵六',
            'age'  => 31,
    ),
    array(
            'id'   => 5,
            'name' => '黄七',
            'age'  => 20,
    ),
); 

$sort = array(
        'direction' => 'SORT_DESC', //排序顺序标志 SORT_DESC 降序;SORT_ASC 升序
        'field'     => 'age',       //排序字段
);
$arrSort = array();
foreach($arrUsers AS $uniqid => $row){
    foreach($row AS $key=>$value){
        $arrSort[$key][$uniqid] = $value;
    }
}
if($sort['direction']){
    array_multisort($arrSort[$sort['field']], constant($sort['direction']), $arrUsers);
}

var_dump($arrUsers);

/*
输出结果:

array (size=5)
  0 =>
    array (size=3)
      'id' => int 5
      'name' => string '黄七' (length=6)
      'age' => int 20
  1 =>
    array (size=3)
      'id' => int 2
      'name' => string '李四' (length=6)
      'age' => int 23
  2 =>
    array (size=3)
      'id' => int 1
      'name' => string '张三' (length=6)
      'age' => int 25
  3 =>
    array (size=3)
      'id' => int 4
      'name' => string '赵六' (length=6)
      'age' => int 31
  4 =>
    array (size=3)
      'id' => int 3
      'name' => string '王五' (length=6)
      'age' => int 40

*/

 

时间: 2024-07-28 21:49:36

PHP 二维数组根据某个字段排序的相关文章

PHP 二维数组根据某个字段排序的具体实现

 本文记录的要实现的功能类似于 MySQL 中的 ORDER BY,上个项目中有遇到这样的一个需求.  要求:从两个不同的表中获取各自的4条数据,然后整合(array_merge)成一个数组,再根据数据的创建时间降序排序取前4条.  遇到这个要求的时候就不是 ORDER BY 能解决的问题了.因此翻看 PHP 手册查找到了如下方法,做此笔记. 废话少说,奉上代码,清单如下:  .代码如下: <?php  /**  * 二维数组根据某个字段排序  * 功能:按照用户的年龄倒序排序  * @auth

PHP 二维数组根据某个字段排序的具体实现_php技巧

本文记录的要实现的功能类似于 MySQL 中的 ORDER BY,上个项目中有遇到这样的一个需求. 要求:从两个不同的表中获取各自的4条数据,然后整合(array_merge)成一个数组,再根据数据的创建时间降序排序取前4条. 遇到这个要求的时候就不是 ORDER BY 能解决的问题了.因此翻看 PHP 手册查找到了如下方法,做此笔记. 废话少说,奉上代码,清单如下: 复制代码 代码如下: <?php /** * 二维数组根据某个字段排序 * 功能:按照用户的年龄倒序排序 * @author r

php自定义函数实现二维数组按指定key排序的方法_php技巧

本文实例讲述了php自定义函数实现二维数组按指定key排序的方法.分享给大家供大家参考,具体如下: 二维数组官方的排序方法并不好,该函数可以进行指定key的排序,已经测试并使用,代码如下: /*二维数组按指定的键值排序*/ function array_sort($arr, $keys, $type = 'desc') { $keysvalue = $new_array = array(); foreach ($arr as $k => $v) { $keysvalue[$k] = $v[$ke

PHP将二维数组某一个字段相同的数组合并起来的方法_php技巧

本文实例讲述了PHP将二维数组某一个字段相同的数组合并起来的方法.分享给大家供大家参考,具体如下: 例子: array(3) { [0]=> array(16) { ["id"]=> string(2) "42" ["uid"]=> string(2) "14" ["euid"]=> string(2) "56" ["did"]=> st

PHP二维数组按照一个字段排序程序

二维数组  代码如下 复制代码 $arr = array (      array ( 'key' => '69931',           'hsex' => '女',           'username' => 'jiayang3401',           'clicks' => 10,           'hyinglou' => '无' ),           array ( 'key' => '81',           'hsex' =>

PHP 多维数组的排序问题 根据二维数组中某个项排序_php技巧

PHP内置函数 array_multisort 要求每个数组大小一样 $areas是地区的二维数组,包含人数和次数,现在要按这2种数进行降序排序 复制代码 代码如下: foreach($areaArray as &$areas) { $times = $numbers = array(); foreach($areas as $province => $v) { $times[$province] = $v['times']; $numbers[$province] = $v['number

PHP排序之二维数组的按照字母排序实现代码_php技巧

复制代码 代码如下: <?php /** * Sort an two-dimension array by some level two items use array_multisort() function. * * sysSortArray($Array,"Key1","SORT_ASC","SORT_RETULAR","Key2"--) * @author Chunsheng Wang <wwccss@26

PHP二维数组怎么按某个字段排序?

  先不说别的我们直接看二维数组按某个字段排序实例  代码如下   <?php         /**        * @author yebihai http://www.45it.com      * @desc 按二维数组的某一个字段进行升降排序        * @data        *      $testData = array(                   array('price'=>19),                   array('price'=>

PHP按指定键值对二维数组进行排序的方法_php技巧

本文实例讲述了PHP按指定键值对二维数组进行排序的方法.分享给大家供大家参考,具体如下: 问题: 有数组: 复制代码 代码如下: array(0=>array('id'=>1,'price'=>50),1=>array('id'=>2,'price'=>60)); 要求根据数组的price这个字段进行排序. 实现代码如下: <?php $array[] = array('id'=>1,'price'=>50); $array[] = array('id