$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);
7条答案
按热度按时间wwwo4jvm1#
2izufjch2#
2fjabf4q3#
你需要让你的函数不区分大小写来得到你想要的“Hello”=〉“hello”结果,试试这个方法:
输出为:
由@AlixAxel编辑:
这个答案很容易让人误解,它只适用于这种特定的情况,下面这个反例:
Fails miserably。另外,这不是保留重复项的方法:
因为其中一个复制值将在
array_unique
中,然后被array_diff
截断。由@RyanDay编辑:
所以看看@Srikanth或@Bucabay的答案,它们适用于所有情况(在Bucabay的答案中寻找大小写不敏感),而不仅仅是问题中指定的测试数据。
cidc1ykv4#
这是正确的方法(区分大小写):
以及不区分大小写的解决方案:
但是@Srikanth的答案更有效(实际上,除了这个答案,它是唯一一个正确工作的答案)。
gtlvzcf85#
Srikanth(john)添加的内容,但不区分大小写。
mrzz3bfm6#
试试看:
不区分大小写:
soat7uwm7#
12年前的帖子和接受的答案返回一个空数组,其他的都是长数组。
这是我对未来谷歌的看法,它很短,返回所有重复的索引(索引?)