繁体   English   中英

根据2个值从多维数组中删除重复项

[英]Remove duplicates from a multi-dimensional array based on 2 values

我有一个看起来像这样的数组

$array = array(
  array("John","Smith","1"),
  array("Bob","Barker","2"),
  array("Will","Smith","2"),
  array("Will","Smith","4")
);

最后,我希望数组看起来像这样

$array = array(
  array("John","Smith","1"),
  array("Bob","Barker","2"),
  array("Will","Smith","2")
);

具有SORT_REGULAR标志的array_unique检查所有三个值。 我已经看到了一些有关如何基于一个值删除重复项的解决方案,但是我需要比较前两个值的唯一性。

使用foreach循环和array_values函数的简单解决方案:

$arr = array(
          array("John","Smith","1"), array("Bob","Barker","2"), 
          array("Will","Smith","2"), array("Will","Smith","4")
);

$result = [];
foreach ($arr as $v) {
    $k = $v[0] . $v[1];  // considering first 2 values as a unique key
    if (!isset($result[$k])) $result[$k] = $v;
}

$result = array_values($result);
print_r($result);

输出:

Array
(
    [0] => Array
        (
            [0] => John
            [1] => Smith
            [2] => 1
        )

    [1] => Array
        (
            [0] => Bob
            [1] => Barker
            [2] => 2
        )

    [2] => Array
        (
            [0] => Will
            [1] => Smith
            [2] => 2
        )
)

带有注释的示例代码:

// array to store already existing values
$existsing = array();
// new array
$filtered = array();

foreach ($array as $item) {
    // Unique key
    $key = $item[0] . ' ' . $item[1];

    // if key doesn't exists - add it and add item to $filtered
    if (!isset($existsing[$key])) {
        $existsing[$key] = 1;
        $filtered[] = $item;
    }
}

为了娱乐。 这将保留最后一次出现,并消除其他出现:

$array = array_combine(array_map(function($v) { return $v[0].$v[1]; }, $array), $array);
  • 映射数组,并从子数组的第一个条目开始构建键
  • 将返回的数组用作新数组中的键,将原始数组用作值

如果要保留第一次出现,则只需在数组前后颠倒数组即可:

$array = array_reverse($array);
$array = array_reverse(array_combine(array_map(function($v) { return $v[0].$v[1]; },
                                               $array), $array));

暂无
暂无

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

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