Уникальный массив с ассоциативным массивом - удаление дубликатов - PullRequest
3 голосов
/ 02 февраля 2011

У меня есть ассоциативный массив с некоторыми дубликатами. Например, у меня есть:

 <? 
 $group_array = array('user_id'=>array(), 'user_first'=>array());

Который выводит что-то вроде ниже:

Array
 (
[user_id] => Array
    (
        [0] => 594
        [1] => 597
        [2] => 594
    )

[user_first] => Array
    (
        [0] => John
        [1] => James
        [2] => John
    )
)

Я бы хотел санировать весь этот массив, чтобы один пользователь Джон однажды появился (на основе user_id).

Я пробовал следующее:

 <?php 
   $unique = array_unique($group_array);
   print_r($unique);

Но, похоже, это не работает. Любые другие идеи, как я могу удалить дубликаты элементов в массиве?

Любая помощь будет отличной!

Ответы [ 4 ]

3 голосов
/ 02 февраля 2011

Другой подход - найти уникальные user_id s и, что важно, их ключи массива, а затем сохранить только соответствующие значения из каждого из столбцов.

$group_array = array(
    'user_id'    => array(594,    597,     594,    598   ),
    'user_first' => array('John', 'James', 'John', 'John'),
);

// Find unique user_ids
$uniques = array_unique($group_array['user_id']);

// Keep only the uniques
foreach ($group_array as $column => $collection) {
    $group_array[$column] = array_intersect_key($collection, $uniques);
}

print_r($group_array);
1 голос
/ 02 февраля 2011

Пара вещей:

функция array_unique не переходит в подмассивы

Прочтите руководство: http://php.net/manual/en/function.array-unique.php «Два элемента считаются равными тогда и только тогда, когда (строка) $ elem1 === (строка) $ elem2. На словах: когда строковое представление совпадает. Первый элемент будет использован."

В вашем случае $ elem1 и $ elem2 - это массивы

0 голосов
/ 21 мая 2016

Возможным решением является использование побочного эффекта фильтрации array_combine(...):

$array = [
    'user_id' => [
        0 => 594,
        1 => 597,
        2 => 594
    ],
    'user_first' => [
        0 => 'John',
        1 => 'James',
        2 => 'John'
    ]
];

$combinedArray = array_combine($array['user_id'], $array['user_first']);

Итак, мы получили массив

Array
(
    [594] => John
    [597] => James
)

Чтобы восстановить исходную структуру, мы просто можем извлечь ключи и значения:

$array = [
    'user_id' => array_keys($combinedArray),
    'user_first' => array_values($combinedArray),
];

Результат:

Array
(
    [user_id] => Array
        (
            [0] => 594
            [1] => 597
        )

    [user_first] => Array
        (
            [0] => John
            [1] => James
        )
)
0 голосов
/ 02 февраля 2011

Этот скрипт удаляет дубликаты на user_id и сохраняет несколько имена, если их идентификаторы разные:

$group_array = Array(
    'user_id' => Array(
        594,
        597,
        594,
        598,
    ),
    'user_first' => Array(
        'John',
        'James',
        'John',
        'John',
    )
);

$dup = array();
for ($i=0; $i<count($group_array['user_id']); $i++) {
    if (in_array($group_array['user_id'][$i], $dup)) {
        unset($group_array['user_id'][$i]);
        unset($group_array['user_first'][$i]);
    } else {
        $dup[] = $group_array['user_id'][$i];
    }
}
print_r($group_array);

выход:

Array
(
    [user_id] => Array
        (
            [0] => 594
            [1] => 597
            [3] => 598
        )

    [user_first] => Array
        (
            [0] => John
            [1] => James
            [3] => John
        )

)
...