多維數(shù)組排序技巧:?jiǎn)尉S排序:使用 sort() 函數(shù)多維排序:使用回調(diào)函數(shù) usort()嵌套排序:使用多個(gè)回調(diào)函數(shù),按指定順序排序不同字段實(shí)戰(zhàn)案例:按姓氏和出生日期對(duì)客戶列表排序
PHP 數(shù)組多維排序的技巧:從新手到精通
數(shù)組排序是 PHP 中一項(xiàng)基本但強(qiáng)大的任務(wù)。當(dāng)涉及到多維數(shù)組時(shí),事情變得更加復(fù)雜,但通過(guò)使用正確的技巧,我們可以輕松高效地對(duì)它們進(jìn)行排序。
新手法
對(duì)于 單維排序,我們可以使用 sort()
函數(shù):
$array = ['a', 'c', 'b']; sort($array); print_r($array); // ['a', 'b', 'c']
登錄后復(fù)制
中級(jí)法
多維排序 需要使用回調(diào)函數(shù):
$array = [ ['name' => 'Alice', 'age' => 30], ['name' => 'Bob', 'age' => 25], ['name' => 'Charlie', 'age' => 35], ]; usort($array, function ($a, $b) { return $a['age'] <=> $b['age']; }); print_r($array); // [ ['name' => 'Bob', 'age' => 25], ['name' => 'Alice', 'age' => 30], ['name' => 'Charlie', 'age' => 35] ]
登錄后復(fù)制
高級(jí)法
嵌套排序 使用多個(gè)回調(diào)函數(shù):
$array = [ ['name' => 'Alice', 'age' => 30], ['name' => 'Bob', 'age' => 25, 'city' => 'New York'], ['name' => 'Charlie', 'age' => 35, 'city' => 'London'], ]; usort($array, function ($a, $b) { if ($a['age'] == $b['age']) { return strcmp($a['city'], $b['city']); } return $a['age'] <=> $b['age']; }); print_r($array); // [ ['name' => 'Bob', 'age' => 25, 'city' => 'New York'], ['name' => 'Alice', 'age' => 30], ['name' => 'Charlie', 'age' => 35, 'city' => 'London'] ]
登錄后復(fù)制
實(shí)戰(zhàn)案例
客戶列表排序:根據(jù)客戶的姓氏和出生日期對(duì)客戶列表進(jìn)行排序。
$customers = [ ['name' => 'John Doe', 'birthdate' => '1980-01-01'], ['name' => 'Jane Doe', 'birthdate' => '1985-03-08'], ['name' => 'Tom Smith', 'birthdate' => '1975-12-15'], ]; usort($customers, function ($a, $b) { if ($a['name'] == $b['name']) { return strtotime($a['birthdate']) <=> strtotime($b['birthdate']); } return strcmp($a['name'], $b['name']); });
登錄后復(fù)制
通過(guò)這些技巧,你可以輕松地對(duì)你項(xiàng)目的 PHP 多維數(shù)組進(jìn)行高效排序,無(wú)論其復(fù)雜程度如何。