评论

评论

这篇文章还没有任何评论。快来成为第一个评论者吧!

对php的列表list按照某个字段排序

举个案例吧,要求显示最新注册的10个 用户,最新注册的显示在最下面。

现在数据库查询按照得到的data数据如下:

$data = array(
  array(
    'name' => '李四',
    'create_time' => '1592848229',//2020/6/23 1:50:29
  ),
  array(
    'name' => '张三',
    'create_time' => '1592847826',//2020/6/23 1:43:46
  ),
  array(
    'name' => '王五',
    'create_time' => '1592848749',//2020/6/23 1:59:9
  )
);

显然按照注册时间我们需要的结果顺序应该是 张三、李四、王五, 所以我们可以这么做:

<?php
$data = array(
  array(
    'name' => '李四',
    'create_time' => '1592848229',//2020/6/23 1:50:29
  ),
  array(
    'name' => '张三',
    'create_time' => '1592847826',//2020/6/23 1:43:46
  ),
  array(
    'name' => '王五',
    'create_time' => '1592848749',//2020/6/23 1:59:9
  )
);
//根据字段create_time对数组$data进行升序排列


//*****************方法一
$create_times = array_column($data,'create_time');
array_multisort($create_times,SORT_ASC,$data);
echo('<pre>');
var_dump($data);
echo('<hr>');

//【测试的时候发现array_column有的时候不好用,可以用方法二】
//*****************方法二
$flag = array();
foreach ($data as $value) {
  $flag[] = $v['create_time'];
}
array_multisort($flag,SORT_ASC,$data);
var_dump($data);
?>

执行结果如下:

array(3) {
  [0]=>
  array(2) {
    ["name"]=>
    string(6) "张三"
    ["create_time"]=>
    string(10) "1592847826"
  }
  [1]=>
  array(2) {
    ["name"]=>
    string(6) "李四"
    ["create_time"]=>
    string(10) "1592848229"
  }
  [2]=>
  array(2) {
    ["name"]=>
    string(6) "王五"
    ["create_time"]=>
    string(10) "1592848749"
  }
}

以下是函数详解:

一、array_column

1)、定义

array_column() 返回输入数组中某个单一列的值。

2)、语法

array_column(array,column_key,index_key);
参数描述
array必需。规定要使用的多维数组(记录集)。
column_key必需。需要返回值的列。可以是索引数组的列的整数索引,或者是关联数组的列的字符串键值。该参数也可以是 NULL,此时将返回整个数组(配合 index_key 参数来重置数组键的时候,非常有用)。
index_key可选。用作返回数组的索引/键的列。

二、array_multisort

1)、定义

array_multisort() 函数返回排序数组。您可以输入一个或多个数组。函数先对第一个数组进行排序,接着是其他数组,如果两个或多个值相同,它将对下一个数组进行排序。

注释:字符串键名将被保留,但是数字键名将被重新索引,从 0 开始,并以 1 递增。

注释:您可以在每个数组后设置排序顺序和排序类型参数。如果没有设置,每个数组参数会使用默认值。

2)、语法

array_multisort(array1,sorting order,sorting type,array2,array3...)
参数描述
array1必需。规定数组。
sorting order可选。规定排列顺序。可能的值:SORT_ASC - 默认。按升序排列 (A-Z)。SORT_DESC - 按降序排列 (Z-A)。
sorting type可选。规定排序类型。可能的值:SORT_REGULAR - 默认。把每一项按常规顺序排列(Standard ASCII,不改变类型)。SORT_NUMERIC - 把每一项作为数字来处理。SORT_STRING - 把每一项作为字符串来处理。SORT_LOCALE_STRING - 把每一项作为字符串来处理,基于当前区域设置(可通过 setlocale() 进行更改)。SORT_NATURAL - 把每一项作为字符串来处理,使用类似 natsort() 的自然排序。SORT_FLAG_CASE - 可以结合(按位或)SORT_STRING 或 SORT_NATURAL 对字符串进行排序,不区分大小写。
array2可选。规定数组。
array3可选。规定数组。
5
分享本页
微信扫一扫浏览本页

我们注意到您的浏览器版本过低。本站需要在更现代的浏览器上才能充分展现,我们推荐您下载谷歌Chrome浏览器来浏览本站。

下载谷歌浏览器