php 仅返回数组中的重复项(不区分大小写)

vddsk6oq  于 2022-12-17  发布在  PHP
关注(0)|答案(7)|浏览(167)

我想从一个数组中检索所有不区分大小写的重复条目。这在PHP中可以实现吗?

array(
    1 => '1233',
    2 => '12334',
    3 => 'Hello',
    4 => 'hello',
    5 => 'U'
);

所需的输出数组:

array(
    1 => 'Hello',
    2 => 'hello'
);
wwwo4jvm

wwwo4jvm1#

function get_duplicates ($array) {
    return array_unique( array_diff_assoc( $array, array_unique( $array ) ) );
}
2izufjch

2izufjch2#

<?php
function array_not_unique($raw_array) {
    $dupes = array();
    natcasesort($raw_array);
    reset($raw_array);

    $old_key   = NULL;
    $old_value = NULL;
    foreach ($raw_array as $key => $value) {
        if ($value === NULL) { continue; }
        if (strcasecmp($old_value, $value) === 0) {
            $dupes[$old_key] = $old_value;
            $dupes[$key]     = $value;
        }
        $old_value = $value;
        $old_key   = $key;
    }
    return $dupes;
}

$raw_array    = array();
$raw_array[1] = 'abc@xyz.com';
$raw_array[2] = 'def@xyz.com';
$raw_array[3] = 'ghi@xyz.com';
$raw_array[4] = 'abc@xyz.com'; // Duplicate

$common_stuff = array_not_unique($raw_array);
var_dump($common_stuff);
2fjabf4q

2fjabf4q3#

你需要让你的函数不区分大小写来得到你想要的“Hello”=〉“hello”结果,试试这个方法:

$arr = array(1=>'1233',2=>'12334',3 =>'Hello' ,4=>'hello', 5=>'U');

// Convert every value to uppercase, and remove duplicate values
$withoutDuplicates = array_unique(array_map("strtoupper", $arr));

// The difference in the original array, and the $withoutDuplicates array
// will be the duplicate values
$duplicates = array_diff($arr, $withoutDuplicates);
print_r($duplicates);

输出为:

Array
(
[3] => Hello
[4] => hello
)

由@AlixAxel编辑:

这个答案很容易让人误解,它只适用于这种特定的情况,下面这个反例:

$arr = array(1=>'1233',2=>'12334',3 =>'Hello' ,4=>'HELLO', 5=>'U');

Fails miserably。另外,这不是保留重复项的方法:

array_diff($arr, array_unique($arr));

因为其中一个复制值将在array_unique中,然后被array_diff截断。

由@RyanDay编辑:

所以看看@Srikanth或@Bucabay的答案,它们适用于所有情况(在Bucabay的答案中寻找大小写不敏感),而不仅仅是问题中指定的测试数据。

cidc1ykv

cidc1ykv4#

这是正确的方法(区分大小写):

array_intersect($arr, array_unique(array_diff_key($arr, array_unique($arr))));

以及不区分大小写的解决方案:

$iArr = array_map('strtolower', $arr);
$iArr = array_intersect($iArr, array_unique(array_diff_key($iArr, array_unique($iArr))));

array_intersect_key($arr, $iArr);

但是@Srikanth的答案更有效(实际上,除了这个答案,它是唯一一个正确工作的答案)。

gtlvzcf8

gtlvzcf85#

function array_not_unique($raw_array) {
    $dupes = array();
    natcasesort($raw_array);
    reset($raw_array);

    $old_key   = NULL;
    $old_value = NULL;
    foreach ($raw_array as $key => $value) {
        if ($value === NULL) { continue; }
        if (strcasecmp($old_value, $value) === 0) {
            $dupes[$old_key] = $old_value;
            $dupes[$key]     = $value;
        }
        $old_value = $value;
        $old_key   = $key;
    } return $dupes;
}

Srikanth(john)添加的内容,但不区分大小写。

mrzz3bfm

mrzz3bfm6#

试试看:

$arr2 = array_diff_key($arr, array_unique($arr));

不区分大小写:

array_diff_key($arr, array_unique(array_map('strtolower', $arr)));
soat7uwm

soat7uwm7#

12年前的帖子和接受的答案返回一个空数组,其他的都是长数组。
这是我对未来谷歌的看法,它很短,返回所有重复的索引(索引?)

$myArray = array('fantastic', 'brilliant', 'happy', 'fantastic', 'Happy', 'wow', 'battlefield2042 :(');

function findAllDuplicates(array $array)
{
    // Remove this line if you do not need case sensitive.
    $array = array_map('strtolower', $array);

    // Remove ALL duplicates
    $removedDuplicates = array_diff($array, array_diff_assoc($array, array_unique($array)));

    return array_keys(array_diff($array, $removedDuplicates));
    // Output all keys with duplicates
    // array(4) {
    //   [0]=>int(0)
    //   [1]=>int(2)
    //   [2]=>int(3)
    //   [3]=>int(4)
    // }

    return array_diff($array, $removedDuplicates);
    // Output all duplicates
    // array(4) {
    //   [0]=>string(9) "fantastic"
    //   [2]=>string(5) "happy"
    //   [3]=>string(9) "fantastic"
    //   [4]=>string(5) "happy"
    // }
}

相关问题