douzhenzu0247 2015-11-06 20:54
浏览 32
已采纳

排序多维数组php

I am trying to sort an array, but by default I can only get it sorted by the record number.

i.e. the array looks like this for example

array(0=array('id','username'), 1=array('id','username'));

if I try to sort it, it sorts by the 0 and 1 values, I cannot get it to sort into the id & username array.

How can i sort the main array acording to the username in the child arrays?

  • 写回答

1条回答 默认 最新

  • droc60607 2015-11-06 21:02
    关注

    Here is what you need to do,

    Sorting using ids

    $a = array(array('idC','usernameC'), array('idA','usernameA'), array('idB','usernameB'));
    $id = array();
    foreach ($a as $key => $row)
    {
        $id[$key] = $row[0];
    }
    array_multisort($id, SORT_ASC, $a);
    
    print_r($a);
    

    will output

    Array
    (
    [0] => Array
        (
            [0] => idA
            [1] => usernameA
        )
    
    [1] => Array
        (
            [0] => idB
            [1] => usernameB
        )
    
    [2] => Array
        (
            [0] => idC
            [1] => usernameC
        )
    
    )
    

    Demo

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 组策略中的计算机配置策略无法下发
  • ¥15 机器学习简单问题解决
  • ¥15 如何绘制动力学系统的相图
  • ¥15 对接wps接口实现获取元数据
  • ¥20 给自己本科IT专业毕业的妹m找个实习工作
  • ¥15 用友U8:向一个无法连接的网络尝试了一个套接字操作,如何解决?
  • ¥30 我的代码按理说完成了模型的搭建、训练、验证测试等工作(标签-网络|关键词-变化检测)
  • ¥50 mac mini外接显示器 画质字体模糊
  • ¥15 TLS1.2协议通信解密
  • ¥40 图书信息管理系统程序编写