답변:
array_unique () 사용하십시오 .
예:
$array = array(1, 2, 2, 3);
$array = array_unique($array); // Array is now (1, 2, 3)
$array = array_unique($array, SORT_REGULAR);
사용하다 array_values(array_unique($array));
array_unique
: 고유 배열의 경우
array_values
: 재색 인화
array_unique
은 키와 값 쌍을 가진 객체를 반환하고 array_values
값만 배열로 반환합니다.
//Find duplicates
$arr = array(
'unique',
'duplicate',
'distinct',
'justone',
'three3',
'duplicate',
'three3',
'three3',
'onlyone'
);
$unique = array_unique($arr);
$dupes = array_diff_key( $arr, $unique );
// array( 5=>'duplicate', 6=>'three3' 7=>'three3' )
// count duplicates
array_count_values($dupes); // array( 'duplicate'=>1, 'three3'=>2 )
독특array_unique()
하고 복제 된 아이템 을 원한다면 때로는 길이 아닙니다 ...
$unique=array("","A1","","A2","","A1","");
$duplicated=array();
foreach($unique as $k=>$v) {
if( ($kt=array_search($v,$unique))!==false and $k!=$kt )
{ unset($unique[$kt]); $duplicated[]=$v; }
}
sort($unique); // optional
sort($duplicated); // optional
에 대한 결과
array ( 0 => '', 1 => 'A1', 2 => 'A2', ) /* $unique */
array ( 0 => '', 1 => '', 2 => '', 3 => 'A1', ) /* $duplicated */
explode(",", implode(",", array_unique(explode(",", $YOUR_ARRAY))));
이것은 키 연결을 처리하고 결과 새 배열의 키를 직렬화합니다 :-)
explode("," $YOUR_ARRAY)
언제 효과 $YOUR_ARRAY
가 array("1", "2", "3")
있습니까?
배열의 크기에 따라
$array = array_values( array_flip( array_flip( $array ) ) );
array_unique보다 빠를 수 있습니다.
PHP의 연관 배열에서 중복 값을 제거하십시오.
$arrDup = Array ('0' => 'aaa-aaa' , 'SKU' => 'aaa-aaa' , '1' => '12/1/1' , 'date' => '12/1/1' , '2' => '1.15' , 'cost' => '1.15' );
foreach($arrDup as $k => $v){
if(!( isset ($hold[$v])))
$hold[$v]=1;
else
unset($arrDup[$k]);
}
배열 ([0] => aaa-aaa [1] => 12/1/1 [2] => 1.15)
성능에 관심이 있고 간단한 배열이있는 경우 다음을 사용하십시오.
array_keys(array_flip($array));
array_unique보다 몇 배 빠릅니다.
$a = array(1, 2, 3, 4);
$b = array(1, 6, 5, 2, 9);
$c = array_merge($a, $b);
$unique = array_keys(array_flip($c));
print_r($unique);
$arrDuplicate = array ("","",1,3,"",5);
foreach(array_unique($arrDuplicate) as $v){
if($v != "" ){$arrRemoved = $v; }}
print_r($arrRemoved);
function arrayUnique($myArray)
{
$newArray = Array();
if (is_array($myArray))
{
foreach($myArray as $key=>$val)
{
if (is_array($val))
{
$val2 = arrayUnique($val);
}
else
{
$val2 = $val;
$newArray=array_unique($myArray);
$newArray=deleteEmpty($newArray);
break;
}
if (!empty($val2))
{
$newArray[$key] = $val2;
}
}
}
return ($newArray);
}
function deleteEmpty($myArray)
{
$retArray= Array();
foreach($myArray as $key=>$val)
{
if (($key<>"") && ($val<>""))
{
$retArray[$key] = $val;
}
}
return $retArray;
}
이 짧고 달콤한 코드를 사용해보십시오-
$array = array (1,4,2,1,7,4,9,7,5,9);
$unique = array();
foreach($array as $v){
isset($k[$v]) || ($k[$v]=1) && $unique[] = $v;
}
var_dump($unique);
출력-
array(6) {
[0]=>
int(1)
[1]=>
int(4)
[2]=>
int(2)
[3]=>
int(7)
[4]=>
int(9)
[5]=>
int(5)
}
if
.
<?php
$arr1 = [1,1,2,3,4,5,6,3,1,3,5,3,20];
print_r(arr_unique($arr1));
function arr_unique($arr) {
sort($arr);
$curr = $arr[0];
$uni_arr[] = $arr[0];
for($i=0; $i<count($arr);$i++){
if($curr != $arr[$i]) {
$uni_arr[] = $arr[$i];
$curr = $arr[$i];
}
}
return $uni_arr;
}
여기에 두 번째 빈 배열을 만들고 for
첫 번째 배열에 루프를 사용하여 중복을 사용했습니다. 첫 번째 배열의 수만큼 많은 시간이 실행됩니다. 그런 다음 첫 번째 배열이있는 배열의 위치와 비교하고을 사용 하여이 항목이 이미 있는지 여부를 일치 in_array
시킵니다. 그렇지 않으면를 사용하여 해당 항목을 두 번째 배열에 추가합니다 array_push
.
$a = array(1,2,3,1,3,4,5);
$count = count($a);
$b = [];
for($i=0; $i<$count; $i++){
if(!in_array($a[$i], $b)){
array_push($b, $a[$i]);
}
}
print_r ($b);
foreach
루프 를 사용하지 않습니까?
foreach
for 루프에 익숙 하기 때문에 사용하지 않은 이유 입니다. 그게 다야.
함수를 통해 수행 할 수 있습니다. 세 개의 함수 복제를 수행하면 배열에 복제 된 값이 반환됩니다.
두 번째 함수 단일은 단일 평균 값이 배열에서 반복되지 않는 값만 반환하고 세 번째 및 전체 함수는 모든 값을 반환하지만 값이 중복되면 복제되지 않는 값을 단일로 변환합니다.
function duplicate($arr) {
$duplicate;
$count = array_count_values($arr);
foreach($arr as $key => $value) {
if ($count[$value] > 1) {
$duplicate[$value] = $value;
}
}
return $duplicate;
}
function single($arr) {
$single;
$count = array_count_values($arr);
foreach($arr as $key => $value) {
if ($count[$value] == 1) {
$single[$value] = $value;
}
}
return $single;
}
function full($arr, $arry) {
$full = $arr + $arry;
sort($full);
return $full;
}
array_unique () 함수의 대안 ..
무차별 대입 알고리즘 사용
// [1] 중복 된 항목이있는 배열
$ matches = [ "jorge", "melvin", "chelsy", "melvin", "jorge", "smith"];
// [2] 중복 된 항목이없는 새 배열의 컨테이너
$ arr = [];
// [3] 복제 된 배열의 길이를 가져 와서 for 루프에 사용할 var len으로 설정합니다.
$ len = count ($ matches);
// [4] 배열 키 ($ i)와 일치하면 현재 루프에서 반복을 사용할 수 없습니다. // [4] 배열 $ arr 다음 일치하는 현재 반복 키 값을 밉니다 [$ i] // [4]를 배열 arr로 보냅니다.
for ($ i = 0; $ i
if(array_search($matches[$i], $arr) === false){ array_push($arr,$matches[$i]); } } //print the array $arr. print_r($arr); //Result: Array ( [0] => jorge [1] => melvin [2] => chelsy [3] => smith )
나는 어떤 기능을 사용하지 않고 이것을했다.
$arr = array("1", "2", "3", "4", "5", "4", "2", "1");
$len = count($arr);
for ($i = 0; $i < $len; $i++) {
$temp = $arr[$i];
$j = $i;
for ($k = 0; $k < $len; $k++) {
if ($k != $j) {
if ($temp == $arr[$k]) {
echo $temp."<br>";
$arr[$k]=" ";
}
}
}
}
for ($i = 0; $i < $len; $i++) {
echo $arr[$i] . " <br><br>";
}
Note that array_unique() is not intended to work on multi dimensional arrays.