如何透過巢狀欄位對多維 PHP 陣列進行高效率排序?
在 PHP 中,可能會遇到表示表格資料的多維數組,其中每個元素保存一個欄位值對的關聯數組。按嵌套數組中的特定欄位對資料進行排序的任務可以輕鬆實現。
考慮以下類似資料庫的陣列:
$data = [ [ 'name' => 'Sony TV', 'price' => 600.00 ], [ 'name' => 'LG TV', 'price' => 350.00 ], [ 'name' => 'Samsung TV', 'price' => 425.00 ] ];
要按' 對此數組進行排序在「價格」欄位中,可以使用array_multisort() 函數和array_column() 函數,從多維數組中提取特定的列(字段)。以下程式碼片段完成此操作:
array_multisort(array_column($data, 'price'), SORT_ASC, $data);
此呼叫將根據「價格」欄位按升序重新排列數組,同時丟棄原始的外部數組鍵。排序後的陣列將顯示為:
[ [ 'name' => 'LG TV', 'price' => 350.00 ], [ 'name' => 'Samsung TV', 'price' => 425.00 ], [ 'name' => 'Sony TV', 'price' => 600.00 ] ]
或者,對於 8 之前的 PHP 版本,由於引用傳遞限制,需要兩行解:
$col = array_column($data, 'price'); array_multisort($col, SORT_ASC, $data);
以上是如何透過嵌套欄位有效率地對多維 PHP 陣列進行排序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!