PHP二維數組中對於兩種不同情況去重的方法

來源:互聯網
上載者:User
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中一維數組的合并與去重的方法

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.