다음 2차원 배열의 경우 중복 제거가 필요합니다.
$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. 2차원 배열 내부의 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/>"; ?>
출력 결과:
배열을 변환하기 전: // 원래 배열
Array ( [0] => Array ( [name] => james [age] => 30 ) [1 ] => 배열 ([이름] => susu [나이] => 26 ) [2] => 배열 ( [이름] => 제임스 [나이]=> 30 ) [신규] => Array ( [이름] => kube [나이] => 37 ) [list] =>Array ( [이름] => kube [나이] => 27 ) )
분할 후 배열: //포스트 배열 분할
배열( [0] => james,30 [1] => susu,26 [2] => james,30 [new ] =>kube,37 [list] = > kube,27 )
배열 중복 제거: //중복 제거 후 배열
Array ( [0] => Array ( [이름] => 제임스 [나이] => 30 ) [1] => Array ([이름] => susu [나이] => 26 ) [신규] => 배열 ( [이름] => kube [나이]=> 37 ) [목록] => 배열 ( [이름] => kube [나이] => 27 ) )
2. 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/>"; ?>
출력 결과:
주어진 키->이름:
Array( [0] => Array( [이름] = > 제임스 [나이] => 30 ) [1 ] => 배열 ([이름] => susu [나이] => 26 ) [신규] => 배열 ( [이름] => age]=> 37 ) )
저작권: 이 글은 블로거의 원본 글이므로 블로거의 허락 없이 복제할 수 없습니다.
위 내용은 PHP에서 2차원 배열의 중복 제거 방법(중복 항목을 제거하면서 각 키 값을 유지하는 방법)을 소개합니다. - 콘텐츠 측면을 포함한 2차원 배열의 고유성, 관심 있는 친구들에게 도움이 되길 바랍니다. PHP 튜토리얼.