首页 > 解决方案 > 如何在 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);

标签: php

解决方案


你可以使用array_multisort.

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

请注意,此函数对原始数组进行操作。如果您想要一个副本,请先构建一个

$copy = $data;

推荐阅读