如何在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);
Quasimodo的克隆

您可以使用array_multisort

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

请注意,此功能在原始阵列上运行。如果您想要复制,请在之前建立一个

$copy = $data;

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章