次の 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 [年齢] => 30 ) [1] = > 配列 ([名前] => ス [年齢] => 26 ) [2] => 配列 ( [名前] => ジェームズ [年齢] => ; 30 ) [新規] => 配列 ( [名前] => クベ [年齢] => 37 ) [リスト] => 配列 ( [名前] => クベ [年齢] => 27 )
配列分割後: //分割後の配列
Array ( [0] => james,30 [1] => susu,26 [2] => james,30 [new] => ;kube,37 [list] => kube,27 )
配列の重複削除: //重複削除後の配列
Array ( [0] => Array ( [name] => james [年齢] => 30 ) [1 ] => 配列 ([名前] => スース [年齢] => 26 ) [新規] => 配列 ( [名前] => クベ [年齢]= > 37 ) [list] => Array ( [name] => kube [age] => 27 ) )
2. 2 次元配列内の 1 次元配列は同じキー値を持つことができないため、重複を削除:
/* 特定のキーに対して重複排除を実行する値*/
<?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/>"; ?>
出力結果:
指定されたキーについては->name:
Array ( [0] => Array ( [名前] => ジェームズ [年齢] = > 30 ) [1] => 配列 ([名前] => スス [年齢] => 配列 ( [名前] = > kube [年齢]=> 37 ) )
著作権に関する声明: この記事はブロガーによるオリジナルの記事であり、ブロガーの許可なく複製することはできません。
以上、PHPにおける二次元配列の重複排除方法(各キー値を保持しながら重複項目を削除する方法)、側面も含めた二次元配列の一意性について紹介しました。PHPチュートリアルに興味のある友人の参考になれば幸いです。