首頁 >後端開發 >php教程 >如何透過嵌套欄位有效率地對多維 PHP 陣列進行排序?

如何透過嵌套欄位有效率地對多維 PHP 陣列進行排序?

DDD
DDD原創
2024-12-02 00:52:14905瀏覽

How to Sort a Multidimensional PHP Array by a Nested Field Efficiently?

如何透過巢狀欄位對多維 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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn