php 多維數(shù)組排序黑魔法:使用自定義函數(shù) compare_students 基于姓名和成績排序。通過 usort() 函數(shù)執(zhí)行排序。php 7.4 中的 uac 提供了更簡潔的匿名類實(shí)現(xiàn)方式。自定義函數(shù)比較輸入數(shù)組,按姓名升序和成績降序排序。
PHP 數(shù)組多維排序的黑魔法:揭秘原理
在 PHP 中,對數(shù)組進(jìn)行多維排序是一項(xiàng)看似復(fù)雜的任務(wù)。然而,掌握適當(dāng)?shù)募夹g(shù)和理解背后的原理,可以讓你輕松駕馭這種黑魔法。
實(shí)戰(zhàn)案例
假設(shè)我們有一個(gè)包含學(xué)生數(shù)據(jù)的數(shù)組,我們希望按姓氏和成績對數(shù)組進(jìn)行排序。
$students = [ ['name' => 'Alice', 'score' => 90], ['name' => 'Bob', 'score' => 85], ['name' => 'Charlie', 'score' => 95], ['name' => 'Dave', 'score' => 80], ];
登錄后復(fù)制
基于自定義函數(shù)的排序
我們可以使用自定義函數(shù) compare_students
來比較兩個(gè)學(xué)生記錄,實(shí)現(xiàn)按姓氏和成績排序:
function compare_students($a, $b) { if ($a['name'] == $b['name']) { return $a['score'] <=> $b['score']; } return strcmp($a['name'], $b['name']); }
登錄后復(fù)制
然后使用 usort()
函數(shù)對數(shù)組進(jìn)行排序:
usort($students, 'compare_students');
登錄后復(fù)制
基于 UAC
PHP 7.4 引入了用戶定義的匿名類 (UAC),這為我們提供了另一種更簡潔的實(shí)現(xiàn)方式:
uasort($students, function($a, $b) { if ($a['name'] == $b['name']) { return $a['score'] <=> $b['score']; } return strcmp($a['name'], $b['name']); });
登錄后復(fù)制
原理揭秘
自定義函數(shù) compare_students
是一個(gè)回調(diào)函數(shù),它根據(jù)兩個(gè)輸入數(shù)組 $a
和 $b
的值比較它們的順序。
該函數(shù)首先檢查兩個(gè)學(xué)生是否具有相同的姓名。如果是,它將比較他們的成績,以便按成績遞減排序。
如果不是,它將使用 strcmp()
函數(shù)比較學(xué)生的姓名,以便按升序排序。
實(shí)戰(zhàn)應(yīng)用
現(xiàn)在,當(dāng)輸出 $students
數(shù)組時(shí),我們將得到按照姓氏和成績排序的結(jié)果:
print_r($students);
登錄后復(fù)制
輸出結(jié)果:
Array ( [0] => Array ( [name] => Alice [score] => 90 ) [1] => Array ( [name] => Bob [score] => 85 ) [2] => Array ( [name] => Charlie [score] => 95 ) [3] => Array ( [name] => Dave [score] => 80 ) )
登錄后復(fù)制