繁体   English   中英

仅保留数组中每个重复值的第一个实例

[英]Mantain only first instance of each duplicated values in array

考虑以下填充数组:

[
  1 => 21
  2 => 19
  3 => 19
  4 => 19
  5 => 18
  6 => 18
  7 => 16
  8 => 15
  9 => 15
  10 => 15
  11 => 15
  12 => 14
  13 => 14
  14 => 14
  15 => 13
  16 => 13
  17 => 12
  18 => 11
  19 => 11
  20 => 11
  21 => 11
  22 => 11
  23 => 9
  24 => 9
  25 => 8
]

我正在尝试迭代这个数组,并且只保留一个和每个重复值的第一个实例,以及 key ,例如我可以有以下输出:

[
  2 => 19
  5 => 18
  8 => 15
  12 => 14
  15 => 13
  18 => 11
  23 => 9
]

到目前为止,我只能维护每个重复值的不稳定实例,从而产生以下输出:

[
  3 => 19
  6 => 18
  9 => 15
  13 => 14
  16 => 13
  19 => 11
  24 => 9
]

我使用以下代码收到此输出:

$arrayFiltered = array_unique(array_diff_assoc($array, array_unique($array)));

更新

根据您的更新,我为您准备了这个。 如果它在$new array 中的计数大于 1(重复),它本质上只会将值返回给$new $array 这就是array_unique()用武之地。它会清理其他所有内容,并且仅根据您的需要向您显示每个副本的第一个实例。

$new = array_unique(array_filter($array, function(&$item) use($array){

    if(count(array_keys($array, $item)) > 1) {
        return $item;
    }

}));

示例/演示

返回:

Array
(
    [2] => 19
    [5] => 18
    [8] => 15
    [12] => 14
    [15] => 13
    [18] => 11
    [23] => 9
)

尝试使用foreach()array_count_values()array_search()如下所示:

$new    =   array();
$multi  =   array_count_values($arr);
foreach($multi as $key => $value) {
        if($value <= 1)
            continue;
        $search         =   array_search($key,$arr);
        $new[$search]   =   $arr[$search];
    }

print_r($new);

给你:

(
    [2] => 19
    [5] => 18
    [8] => 15
    [12] => 14
    [15] => 13
    [18] => 11
    [23] => 9
)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM