PHP中怎么利用uasort()自定义排序 多维数组,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。php内置的排序函数很多;正反各种排;常用的
PHP中怎么利用uasort()自定义排序 多维数组,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
php内置的排序函数很多;正反各种排;
常用的排序函数:
sort() - 以升序对数组排序
rsort() - 以降序对数组排序
asort() - 根据值,以升序对关联数组进行排序
ksort() - 根据键,以升序对关联数组进行排序
arsort() - 根据值,以降序对关联数组进行排序
krsort() - 根据键,以降序对关联数组进行排序
基本都能满足需求了;关于这些函数的使用方法就不多啰嗦了;
但是在项目的实际开发中还是会有些更加苛刻的排序需求;今天要介绍的排序函数是: uasort()
uasort主要是用在需要按照自定义的方法并且保留索引关系对多维数组的排序上;
有如下数组
$sort_array = array(
"array1" => array(
'Word'=>'test1',
'sortnumber'=>1,
),
'array3'=>array(
'word'=>'test4',
'sortnumber'=>4,
),
'array2'=>array(
'word'=>'test3',
'sortnumber'=>3,
),
'array5'=>array(
'word'=>'test5',
),
'array4'=>array(
'word'=>'test2',
'sortnumber'=>2,
),
);
需求是按照sortnumber以升序的方式排序;
首先需要写一个自定义排序的规则;
// 自定义排序函数
function my_sort($a,$b){
$prev = isset($a['sortnumber']) ? $a['sortnumber'] : 0;
$next = isset($b['sortnumber']) ? $b['sortnumber'] : 0;
if($prev == $next)return 0;
return ($prev<$next) ? -1 : 1;
}
echo '<pre>排序前:<br>';
print_r($sort_array);
uasort($sort_array, "my_sort");
echo "排序后:<br>";
print_r ($sort_array);
得到的结果:
排序前:
Array
(
[array1] => Array
(
[word] => test1
[sortnumber] => 1
)
[array3] => Array
(
[word] => test4
[sortnumber] => 4
)
[array2] => Array
(
[word] => test3
[sortnumber] => 3
)
[array5] => Array
(
[word] => test5
)
[array4] => Array
(
[word] => test2
[sortnumber] => 2
)
)
排序后:
Array
(
[array5] => Array
(
[word] => test5
)
[array1] => Array
(
[word] => test1
[sortnumber] => 1
)
[array4] => Array
(
[word] => test2
[sortnumber] => 2
)
[array2] => Array
(
[word] => test3
[sortnumber] => 3
)
[array3] => Array
(
[word] => test4
[sortnumber] => 4
)
)
看完上述内容,你们掌握php中怎么利用uasort()自定义排序 多维数组的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网PHP编程频道,感谢各位的阅读!
--结束END--
本文标题: php中怎么利用uasort()自定义排序 多维数组
本文链接: https://lsjlt.com/news/76033.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0