想要實現二維數組中根據某個欄位排序,一般可以通過數組迴圈對比的方式實現。這裡介紹一種更簡單的方法,直接通過PHP函數實現。array_multisort() :可以用來一次對多個數組進行排序,或者根據某一維或多維對多維數組進行排序。詳細介紹可參考PHP手冊:https://www.php.net/m ...
想要實現二維數組中根據某個欄位排序,一般可以通過數組迴圈對比的方式實現。這裡介紹一種更簡單的方法,直接通過PHP函數實現。
array_multisort() :可以用來一次對多個數組進行排序,或者根據某一維或多維對多維數組進行排序。
詳細介紹可參考PHP手冊:https://www.php.net/manual/zh/function.array-multisort.php
實例:
1、單個欄位排序:
$data = [ ['id' => 1, 'name' => '張三', 'sort' => 60], ['id' => 2, 'name' => '李四', 'sort' => 40], ['id' => 3, 'name' => '王五', 'sort' => 80], ]; // 先取出要排序的欄位的值 $sort = array_column($data, 'sort'); // 按照sort欄位升序 其中SORT_ASC表示升序 SORT_DESC表示降序 array_multisort($sort, SORT_ASC, $data); // 輸出結果 var_dump($data);
2、多個欄位排序:
$data = [ ['id' => 1, 'name' => '張三', 'sort' => 60], ['id' => 2, 'name' => '李四', 'sort' => 60], ['id' => 3, 'name' => '王五', 'sort' => 80], ]; // 先取出要排序的欄位的值 $sort = array_column($data, 'sort'); $name = array_column($data, 'name'); // 先按照sort欄位升序,再按照name欄位降序 array_multisort($sort, SORT_ASC, $name, SORT_DESC, $data); // 輸出結果 var_dump($data);