PHP でデータ処理を行うと、データを格納する配列があるのに、配列内に重複した要素が存在するため、重複した要素を削除する必要があるという問題に遭遇することがあります。では、この問題をどうやって解決すればいいのでしょうか?
方法 1: PHP 独自の関数 array_unique を使用する
PHP には、配列の重複排除機能を実現できる非常に便利な関数 array_unique が用意されています。
使用法は次のとおりです:
array array_unique ( array $array [, int $sort_flags = SORT_STRING ] )
ここで、$array は重複排除する必要がある配列で、$sort_flags は並べ替え方法を示すオプションのパラメーターです。
この関数の原理は次のとおりです。新しい空の配列を作成し、元の配列の要素を走査します。要素が新しい配列に存在しない場合は、その要素を新しい配列に追加します。
例:
$arr = array(1, 2, 2, 3, 4, 4, 4, 5); $arr = array_unique($arr); print_r($arr);
出力結果は次のとおりです:
Array ( [0] => 1 [1] => 2 [3] => 3 [4] => 4 [7] => 5 )
ご覧のとおり、元の配列内の重複要素が削除されています。
方法 2: 配列を走査する
PHP に付属の関数を使用することに加えて、配列を走査することによって重複排除を実現することもできます。
具体的な方法は次のとおりです。新しい空の配列を作成し、元の配列の要素を走査します。要素が新しい配列に存在しない場合は、その要素を新しい配列に追加します。
コードは次のように実装されます:
$arr = array(1, 2, 2, 3, 4, 4, 4, 5); $new_arr = array(); // 新数组 foreach ($arr as $value) { if (!in_array($value, $new_arr)) { // $value 在 $new_arr 中不存在 $new_arr[] = $value; // 添加到 $new_arr 中 } } print_r($new_arr); // 输出新数组
出力結果は次のとおりです:
Array ( [0] => 1 [1] => 2 [3] => 3 [4] => 4 [7] => 5 )
方法 1 と比較すると、この方法は比較的面倒ですが、基礎となる原理を知っておくと、 PHP 配列を理解する上で非常に重要であり、内部メカニズムは役に立ちます。
方法 2 は、トラバーサル中に新しい配列に要素が存在するかどうかを判断する必要があるため、効率が比較的低いことに注意してください。元の配列の要素数が多い場合、実行時間は長くなる可能性があります。より長いです。
要約すると、PHP 配列の重複排除には主に 2 つの方法があります: PHP の組み込み関数 array_unique を使用する方法と、配列を走査する方法です。どちらの方法でも重複排除機能を実現できますが、そのうちの 1 つは PHP の組み込み関数 array_unique を使用する方法です。より効果的で、シンプルかつ高速です。
以上がPHP で配列から重複データを削除する 2 つの方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。