Если я 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,
),
Даты перепутаны. Я пытаюсь отсортировать эти даты и сохранить идентификаторы, прикрепленные к каждой дате 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);






Возможно, попробуйте изменить сравнение, чтобы отсортировать в порядке убывания:
return $b['date'] - $a['date'];
но посмотрите на экспорт var, даты перепутаны, так что дело не в обратном порядке
Интересный роб.м. Можете ли вы включить код, который сортирует и выгружает массив?
В вашем вопросе упоминается var_export до usort. Кажется, вы делаете это не в том порядке.
Вы можете использовать array_multisort.
array_multisort($data, SORT_DESC, array_column($data, 'date'));
var_dump($data);
Обратите внимание, что эта функция работает с исходным массивом. Если вам нужна копия, создайте ее перед
$copy = $data;
@Emma См. редактирование, мультисортировка даже использует константу SORT_DESC.
@Emma обновила вопрос