如何对多维数组进行排序?

时间:2019-02-07 02:39:33

标签: php

如果我var_export我得到

array (
  0 => 
  array (
    'date' => 2017,
    'id' => 128343,
  ),
  1 => 
  array (
    'date' => 1976,
    'id' => 128315,
  ),
  2 => 
  array (
    'date' => 2006,
    'id' => 128310,
  ),
  3 => 
  array (
    'date' => 1967,
    'id' => 128304,
  ),
  4 => 
  array (
    'date' => 1938,
    'id' => 128295,
  ),
  5 => 
  array (
    'date' => 1978,
    'id' => 128293,
  ),
  6 => 
  array (
    'date' => 1997,
    'id' => 128157,
  ),
  7 => 
  array (
    'date' => 2000,
    'id' => 128124,
  ),

日期混合了。我试图对这些日期进行排序,并将ID附加在每个日期DESC上,以便再次循环但有序。我尝试过

function custom_sort_dt($a, $b) {
   return $a['date'] - $b['date'];
}
usort($dateOrdered, "custom_sort_dt");

但是我仍然得到错误的命令。

// the following gives a date
$myDate = (int)get_post_meta($id, 'usp-custom-14', true);

// this attaches the Id and the date
$dateOrdered[] = array("date"=>$myDate, "id"=>$id);

2 个答案:

答案 0 :(得分:4)

您可以使用array_multisort

array_multisort($data, SORT_DESC, array_column($data, 'date'));
var_dump($data);

请注意,此函数在原​​始阵列上运行。如果您想要副本,请先通过

建立一个副本
$copy = $data;

答案 1 :(得分:2)

也许尝试反转比较以降序排列:

return $b['date'] - $a['date'];