PHP の 2 次元配列の重複排除は、2 次元配列内の 1 次元配列の値が完全に同じになることができず、重複した項目が削除される場合と、もう 1 つの場合に分けられます。 2 次元配列内の 1 次元配列 配列内の特定のキー値が同じであることはできないため、重複する項目は削除されます。
次の 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] => Array ([name] ] =>すす [年齢] => 26 ) [2] => Array ( [名前] => ジェームズ [年齢]=> 30 ) [新規] => Array ( [名前] => ; kube [age] => 37 ) [list ] =>Array ( [name] => kube [age] => 27 ) )
配列の分割後: //分割後の配列 #Array ( [0] => james,30 [1] => susu,26 [2] => james,30 [new] =>kube,37 [list] => kube,27 )
配列の重複削除: //重複排除後の配列Array ( [0] = > Array ( [名前] => ジェームズ [年齢] => 30 ) [1] => 配列 ([名前] => すす [年齢] => 26 ) [新規] => 配列 ( [名前] => kube [年齢] => 37 ) [リスト] => Array ( [名前] => kube [年齢] => 27 ) )
778e548d6ce61c52a24e04daddb7351e $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:0c6dc11e160d3b678d68754cc175188a",$key); print_r($arr_key); echo "076402276aae5dbec7f672f8f4e5cc81"; ?>
出力結果:
指定されたキーについては->name:Array ( [0] => Array ( [name] => james [age] => 30 ) [ 1] => Array ([name] => susu [age] => 26 ) [new] => Array ( [name] => kube [age]=> 37 ) )
以上がPHP の 2 次元配列における 2 つの異なる状況における重複排除の方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。