按多列對多維數組排序
對多維數組進行排序可能是一項具有挑戰性的任務,尤其是在考慮多個條件時。幸運的是,PHP 提供了 array_multisort 函數形式的優雅解決方案。
要對多維數組進行排序,我們需要提取所需的列並將它們傳遞給 array_multisort。每列獨立排序,排序順序指定為 SORT_ASC 或 SORT_DESC。
例如,給定以下輸入陣列:
$array = [ ['ID' => 1, 'title' => 'Boring Meeting', 'date_start' => '2010-07-30', 'event_type' => 'meeting', 'state' => 'new-york'], ['ID' => 2, 'title' => 'Find My Stapler', 'date_start' => '2010-07-22', 'event_type' => 'meeting', 'state' => 'new-york'], ['ID' => 3, 'title' => 'Mario Party', 'date_start' => '2010-07-22', 'event_type' => 'party', 'state' => 'new-york'], ['ID' => 4, 'title' => 'Duct Tape Party', 'date_start' => '2010-07-28', 'event_type' => 'party', 'state' => 'california'] ];
按state 排序,然後按event_type 排序,最後按event_type 排序date_start,我們將使用以下程式碼:
# extract columns $state = array_column($array, 'state'); $event_type = array_column($array, 'event_type'); $date_start = array_column($array, 'date_start'); # sort by state desc, event_type asc, date_start asc array_multisort($state, SORT_DESC, $event_type, SORT_ASC, $date_start, SORT_ASC, $array);
PHP 5.5.0引入了一個簡化的語法,使用array_column:
array_multisort( array_column($array, 'state'), SORT_DESC, array_column($array, 'event_type'), SORT_ASC, $array );
排序後的數組如下所示:
[ ['ID' => 4, 'title' => 'Duct Tape Party', 'date_start' => '2010-07-28', 'event_type' => 'party', 'state' => 'california'], ['ID' => 3, 'title' => 'Mario Party', 'date_start' => '2010-07-22', 'event_type' => 'party', 'state' => 'new-york'], ['ID' => 2, 'title' => 'Find My Stapler', 'date_start' => '2010-07-22', 'event_type' => 'meeting', 'state' => 'new-york'], ['ID' => 1, 'title' => 'Boring Meeting', 'date_start' => '2010-07-30', 'event_type' => 'meeting', 'state' => 'new-york'], ];
透過利用array_multisort,我們可以有效地根據多列對多維數組進行排序,提供了靈活而強大的排序方法資料組織和檢索的解決方案。
以上是如何使用「array_multisort」以多列排序 PHP 中的多維數組?的詳細內容。更多資訊請關注PHP中文網其他相關文章!