PHP:按值对对象数组进行分组的函数

时间:2010-12-01 22:24:33

标签: php unique

我正在使用多维数组。如何按值删除重复项?在以下数组中,[0],[2]和[5]具有相同的[ID]。是否有一个函数可以根据特定值删除任何重复的数组?在这种情况下,我想删除array [2]和array [5],因为它们与array [0]具有相同的[ID]。

感谢您提供任何信息。

        Array
(
    [0] => stdClass Object
        (
            [d] => 2010-10-18 03:30:04
            [ID] => 9
        )

    [1] => stdClass Object
        (
            [d] => 2010-10-18 03:30:20
            [ID] => 4
        )

    [2] => stdClass Object
        (
            [d] => 2010-11-03 16:46:34
            [ID] => 9
        )

    [3] => stdClass Object
        (
            [d] => 2010-11-02 03:19:14
            [ID] => 1
        )

    [4] => stdClass Object
        (
            [d] => 2010-05-12 04:57:34
            [ID] => 2
        )    

    [5] => stdClass Object
        (
            [d] => 2010-05-10 05:24:15
            [ID] => 9
        )

)

6 个答案:

答案 0 :(得分:5)

一种方法:( $old_array是您的数组,$new_array将包含新的数据,删除的dupes,由该ID键入)

$new_array = array();
foreach ($old_array as $item)
  if (!array_key_exists($item->ID, $new_array))
    $new_array[$item->ID] = $item;

(我没有测试过这个,但它应该有用)

答案 1 :(得分:3)

您可以使用ouzo goodies

执行此操作
$result = FluentArray::from($array)->uniqueBy('ID')->toArray();

请参阅http://ouzo.readthedocs.org/en/latest/utils/fluent_array.html#uniqueby

答案 2 :(得分:0)

我认为循环并构造一个新数组是最容易的。在循环中,使用array_key_exists()来确定新数组中是否已存在ID,如果不存在,则追加元素。

答案 3 :(得分:0)

多维数组,它是对象数组。你可以循环它(这个例子改变了数组):

$ids = array();

forach($array as $key=>$obj) {
    if(isset($ids[$obj->ID])) {//did we already encounter an object with this ID?
        unset($array[$key]); // if yes, delete this object
    }
    else {
        $ids[$obj->ID] = 1; // if not, add ID to processed IDs
    }
}

您还可以创建一个新数组并将对象添加到新数组中。

答案 4 :(得分:0)

foreach ($array as $element) {
    foreach ($array as &$element2) {
        if ($element2->ID == $element->ID && $element2 != $element) {
            unset($element2);
        }
    }
}

请注意第二个foreach中的循环引用。

答案 5 :(得分:0)

indexed检查Nspl功能。

use function \nspl\op\propertyGetter;
use function \nspl\a\indexed;

$groupedById = indexed($objects, propertyGetter('id'));