> 백엔드 개발 > PHP 튜토리얼 > PHP 2차원 배열 중복 제거 방법(중복 항목을 제거하면서 각 키 값은 유지) - 2차원 배열의 고유성

PHP 2차원 배열 중복 제거 방법(중복 항목을 제거하면서 각 키 값은 유지) - 2차원 배열의 고유성

WBOY
풀어 주다: 2016-07-30 13:30:25
원래의
1594명이 탐색했습니다.

다음 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(
          &#39;0&#39;=>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 튜토리얼.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿