各类知识收集,PHP技术分享与解决方案各类知识收集,PHP技术分享与解决方案各类知识收集,PHP技术分享与解决方案

Str Tom,为分享PHP技术和解决方案,贡献一份自己的力量!
收藏本站(不迷路),每天更新好文章!
当前位置:首页 > CMS教程 > PHP

PHP二维数组中对于两种不同情况去重的方法

管理员 2023-09-05
PHP
164

PHP二维数组中对于两种不同情况去重的方法

内容导读

收集整理的这篇技术教程文章主要介绍了PHP二维数组中对于两种不同情况去重的方法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3170字,纯文字阅读大概需要5分钟

内容图文

PHP二维数组去重分为两种情况,一种是二维数组内部的一维数组中的值不能完全相同,删除其中重复的项,另一种是二维数组内部的一维数组因某一个键值不能相同,删除其重复的项。

对于如下二维数组,要求对其进行去重:

$arr = array(          '0'=>array(                    'name'=>'james',                    'age'=>30,                    ),          '1'=>array(                    'name'=>'susu',                    'age'=>26,                    ),          '2'=>array(                    'name'=>'james',                    'age'=>30,                    ),          'new'=>array(                    'name'=>'kube',                    'age'=>37,                    ),          'list'=>array(                    'name'=>'kube',                    'age'=>27,                    ),          );

1、 二维数组内部的一维数组中的值不能完全相同,删除其中重复的项:

代码如下:

<?php$arr = array(          '0'=>array(                   'name'=>'james',                   'age'=>30,                   ),          '1'=>array(                   'name'=>'susu',                   'age'=>26,                   ),           '2'=>array(                   'name'=>'james',                   'age'=>30,                   ),           'new'=>array(                   'name'=>'kube',                   'age'=>37,                   ),           'list'=>array(                   'name'=>'kube',                   'age'=>27,                   ),           );printf("Before tranform the array:<br>");   //
输出原来的数组print_r($arr);echo "<br/>";function more_array_unique($arr=array()){ foreach($arr[0] as $k => $v){ $arr_inner_key[]= $k; //先把二维数组中的内层数组的键值记录在在一维数组中 } foreach ($arras $k => $v){ $v =join(",",$v); //降维 用implode()也行 $temp[$k] =$v; //保留原来的键值 $temp[]即为不保留原来键值 } printf("After split the array:<br>"); print_r($temp); //输出拆分后的数组 echo"<br/>"; $temp =array_unique($temp); //去重:去掉重复的字符串 foreach ($tempas $k => $v){ $a = explode(",",$v); //拆分后的重组 如:Array( [0] => james [1] => 30 ) $arr_after[$k]= array_combine($arr_inner_key,$a); //将原来的键与值重新合并 } //ksort($arr_after);//排序如需要:ksort对数组进行排序(保留原键值key) ,sort为不保留key值 return$arr_after;} $arr_new = more_array_unique($arr); //调用去重函数 printf("Duplicate removal of the array:<br>"); print_r($arr_new);echo "<br/>";?>

输出结果:

Before tranform the array: //原来数组
Array ( [0] => Array ( [name] => james [age] => 30 ) [1] => Array ([name] => susu [age] => 26 ) [2] => Array ( [name] => james [age]=> 30 ) [new] => Array ( [name] => kube [age] => 37 ) [list] =>Array ( [name] => kube [age] => 27 ) )
After split the array: //拆分后数组
Array ( [0] => james,30 [1] => susu,26 [2] => james,30 [new] =>kube,37 [list] => kube,27 )
Duplicate removal of thearray: //去重后数组
Array ( [0] => Array ( [name] => james [age] => 30 ) [1] => Array ([name] => susu [age] => 26 ) [new] => Array ( [name] => kube [age]=> 37 ) [list] => Array ( [name] => kube [age] => 27 ) )

2、 二维数组内部的一维数组因某一个键值不能相同,删除重复项:

/*针对某一个键值来进行去重*/

<?php$arr= array(……);  //同上的二维数组functionsecond_array_unique_bykey($arr, $key){    $tmp_arr = array();    foreach($arr as $k => $v)    {        if(in_array($v[$key], $tmp_arr))   //搜索$v[$key]是否在$tmp_arr数组中存在,若存在返回true        {            unset($arr[$k]); //销毁一个变量  如果$tmp_arr中已存在相同的值就删除该值        }        else {            $tmp_arr[$k] = $v[$key];  //将不同的值放在该数组中保存        }   }   //ksort($arr); //ksort函数对数组进行排序(保留原键值key)  sort为不保留key值    return $arr;   }   $key ='name';   $arr_key = second_array_unique_bykey($arr,$key);   printf("As for the givenkey->%s:<br>",$key);   print_r($arr_key);   echo "<br/>";?>

输出结果:

As for the given key->name:
Array ( [0] => Array ( [name] => james [age] => 30 ) [1] => Array ([name] => susu [age] => 26 ) [new] => Array ( [name] => kube [age]=> 37 ) )

相关推荐:

PHP中一维数组的合并与去重的方法

以上就是PHP二维数组中对于两种不同情况去重的方法的详细内容,更多请关注Gxl网其它相关文章!

内容总结

以上是为您收集整理的PHP二维数组中对于两种不同情况去重的方法全部内容,希望文章能够帮你解决PHP二维数组中对于两种不同情况去重的方法所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

相关推荐

扫码关注

qrcode

QQ交谈

回顶部