dougua9165 2015-10-08 04:51
浏览 62
已采纳

合并,删除重复项并在php中排序关联数组

I am trying to merge arrays in php. Everything is coming from a database and two different results could look like this:

array[0]['id_user'] = 1
array[0]['tokenId'] = 123
array[1]['id_user'] = 2
array[1]['tokenId'] = 456
array[2]['id_user'] = 5
array[2]['tokenId'] = 789

array[0]['id_user'] = 1
array[0]['tokenId'] = 123
array[1]['id_user'] = 2
array[1]['tokenId'] = 752
array[2]['id_user'] = 3
array[2]['tokenId'] = 789

Using array_merge() and then array_unique() should give me something like this I expect:

unique_and_merged_array[0]['id_user'] = 1
unique_and_merged_array[0]['tokenId'] = 123
unique_and_merged_array[1]['id_user'] = 2
unique_and_merged_array[1]['tokenId'] = 456
unique_and_merged_array[2]['id_user'] = 5
unique_and_merged_array[2]['tokenId'] = 789
unique_and_merged_array[3]['id_user'] = 2
unique_and_merged_array[3]['tokenId'] = 752
unique_and_merged_array[4]['id_user'] = 3
unique_and_merged_array[4]['tokenId'] = 789

Then how can I sort by id_user value? I'm not sure to understand the different sorting php functions ...

  • 写回答

3条回答 默认 最新

  • douya7282 2015-10-08 05:35
    关注

    The PHP-based solution could look something like this:

    //Define arrays for testing
    $array1[0]['id_user'] = 1;
    $array1[0]['tokenId'] = 123;
    $array1[1]['id_user'] = 2;
    $array1[1]['tokenId'] = 456;
    $array1[2]['id_user'] = 5;
    $array1[2]['tokenId'] = 789;
    
    $array2[0]['id_user'] = 1;
    $array2[0]['tokenId'] = 123;
    $array2[1]['id_user'] = 2;
    $array2[1]['tokenId'] = 752;
    $array2[2]['id_user'] = 3;
    $array2[2]['tokenId'] = 789;
    
    //Define sort function - compares arrays using the 'id_user' value
    function sortByUserId($array1, $array2)
    {
        if ($array1['id_user'] == $array2['id_user']) {
            return 0;
        }
        return ($array1['id_user'] < $array2['id_user']) ? -1 : 1;
    }
    
    //Merge arrays
    $unique_and_merged_array = array_merge($array1, $array2);
    
    //Remove duplicate entries - note SORT_REGULAR in order to work with multidimensional arrays
    $unique_and_merged_array = array_unique($unique_and_merged_array, SORT_REGULAR);
    
    //Sort the arrays
    uasort($unique_and_merged_array, 'sortByUserId');
    
    //Enjoy  ;)
    var_dump($unique_and_merged_array);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 wpf界面一直接收PLC给过来的信号,导致UI界面操作起来会卡顿
  • ¥15 init i2c:2 freq:100000[MAIXPY]: find ov2640[MAIXPY]: find ov sensor是main文件哪里有问题吗
  • ¥15 运动想象脑电信号数据集.vhdr
  • ¥15 三因素重复测量数据R语句编写,不存在交互作用
  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒