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






