在 PHP 中,usort()
函数用于对数组进行排序,它允许你使用自定义的比较函数来确定元素的顺序。以下是 usort()
函数的使用方法:
usort(array &$array, callable $cmp_function): bool
参数说明:
$array
:要排序的数组,是传入函数的引用。$cmp_function
:自定义的比较函数,用于确定元素的顺序。返回值:
如果成功排序数组,则返回 true
,否则返回 false
。
使用 usort()
函数时,你需要提供一个自定义的比较函数,该函数定义了元素之间的排序规则。比较函数应该接受两个参数,即要比较的两个元素,并返回一个整数值,表示它们的相对顺序。
下面是一个示例,演示如何使用 usort()
函数对数组进行排序:
// 自定义比较函数
function compare($a, $b) {
// 按照字符串长度进行排序
if (strlen($a) < strlen($b)) {
return -1;
} elseif (strlen($a) > strlen($b)) {
return 1;
} else {
return 0;
}
}
// 要排序的数组
$array = array("apple", "banana", "cherry", "date");
// 使用 usort 函数进行排序
usort($array, "compare");
// 打印排序后的数组
print_r($array);
输出结果:
Array
(
[0] => date
[1] => apple
[2] => banana
[3] => cherry
)
在上面的示例中,我们定义了一个名为 compare
的自定义比较函数,它根据字符串的长度确定元素的顺序。然后,我们使用 usort()
函数将数组 $array
按照该比较函数进行排序。最后,我们打印排序后的数组,得到了按照字符串长度递增的顺序排列的元素。
这里再举一个稍微复杂一点的数组排序的列子:
如何将一个二维数组安某一列的值在另一个一维数组的顺序排序:
$arra = ['5413_BJ063','5408_BJ062','5278_BJ061','5043_BJ059','5018_BJ058','2256_BJ004','2264_BJ012','2274_BJ022'];
$arrb =[
['name'=>'11111','sn'=>'5018_BJ058','prrice'=>30],
['name'=>'22222','sn'=>'5413_BJ063','prrice'=>40],
['name'=>'33333','sn'=>'2256_BJ004','prrice'=>20],
['name'=>'4444','sn'=>'5018_BJ058','prrice'=>10],
['name'=>'5555','sn'=>'2264_BJ012','prrice'=>5],
['name'=>'6666','sn'=>'5043_BJ059','prrice'=>25],
['name'=>'77777','sn'=>'5018_BJ058','prrice'=>12],
['name'=>'88888','sn'=>'2274_BJ022','prrice'=>60],
['name'=>'99999','sn'=>'5408_BJ062','prrice'=>70],
]
foreach(array_reverse($arra) as $itemv){
$GLOBALS['itemv'] = $itemv;
usort($dgtop_goods, function ($a, $b) {
if ($b['goods_sn'] == $GLOBALS['itemv']) {
return 1;
};
return $a['goods_sn'] == $GLOBALS['itemv'] ? 0 : 0;
});
}
这种一般用在把查出来的文章或商品按指定的顺序排序的情况,非常有用,实现时用到了php的两个函数
array_reverse
usort
期望对大家有用