PHP二维数组根据某个字段排序

代码示例:

  1. $arr = [
  2. [
  3. 'name' => '张三',
  4. 'age' => 20
  5. ],
  6. [
  7. 'name' => '李四',
  8. 'age' => 50
  9. ],
  10. [
  11. 'name' => '王五',
  12. 'age' => 32
  13. ],
  14. [
  15. 'name' => '赵六',
  16. 'age' => 12
  17. ],
  18. [
  19. 'name' => '孙七',
  20. 'age' => 44
  21. ],
  22. ];
  23. array_multisort(array_column($arr, 'age'), SORT_DESC, $arr);
  24. var_dump($arr);

本文来自于 CSDN,原文地址:http://blog.csdn.net/liruxing1715/article/details/28265495

本文记录的要实现的功能类似于 MySQL 中的 ORDER BY,上个项目中有遇到这样的一个需求。

要求:从两个不同的表中获取各自的4条数据,然后整合(array_merge)成一个数组,再根据数据的创建时间降序排序取前4条。

遇到这个要求的时候就不是 ORDER BY 能解决的问题了。因此翻看 PHP 手册查找到了如下方法,做此笔记。 废话少说,奉上代码,清单如下:

  1. /**
  2. * 二维数组根据某个字段排序
  3. * 功能:按照用户的年龄倒序排序
  4. * @author ruxing.li
  5. */
  6. header('Content-Type:text/html;Charset=utf-8');
  7. $arrUsers = array(
  8. array(
  9. 'id' => 1,
  10. 'name' => '张三',
  11. 'age' => 25,
  12. ),
  13. array(
  14. 'id' => 2,
  15. 'name' => '李四',
  16. 'age' => 23,
  17. ),
  18. array(
  19. 'id' => 3,
  20. 'name' => '王五',
  21. 'age' => 40,
  22. ),
  23. array(
  24. 'id' => 4,
  25. 'name' => '赵六',
  26. 'age' => 31,
  27. ),
  28. array(
  29. 'id' => 5,
  30. 'name' => '黄七',
  31. 'age' => 20,
  32. ),
  33. );
  34. $sort = array(
  35. 'direction' => 'SORT_DESC', //排序顺序标志 SORT_DESC 降序;SORT_ASC 升序
  36. 'field' => 'age', //排序字段
  37. );
  38. $arrSort = array();
  39. foreach($arrUsers AS $uniqid => $row){
  40. foreach($row AS $key=>$value){
  41. $arrSort[$key][$uniqid] = $value;
  42. }
  43. }
  44. if($sort['direction']){
  45. array_multisort($arrSort[$sort['field']], constant($sort['direction']), $arrUsers);
  46. }
  47. var_dump($arrUsers);
  48. /*
  49. 输出结果:
  50. array (size=5)
  51. 0 =>
  52. array (size=3)
  53. 'id' => int 5
  54. 'name' => string '黄七' (length=6)
  55. 'age' => int 20
  56. 1 =>
  57. array (size=3)
  58. 'id' => int 2
  59. 'name' => string '李四' (length=6)
  60. 'age' => int 23
  61. 2 =>
  62. array (size=3)
  63. 'id' => int 1
  64. 'name' => string '张三' (length=6)
  65. 'age' => int 25
  66. 3 =>
  67. array (size=3)
  68. 'id' => int 4
  69. 'name' => string '赵六' (length=6)
  70. 'age' => int 31
  71. 4 =>
  72. array (size=3)
  73. 'id' => int 3
  74. 'name' => string '王五' (length=6)
  75. 'age' => int 40
  76. */

发表评论

邮箱地址不会被公开。 必填项已用*标注

发表评论前,请滑动滚动条解锁
三十岁