php возвращают только дублированные записи из массива

Метки из набора данных MNIST в sklearn содержат строки, а не целые числа. Итак, установите

y_train_5 = (y_train == '9')
y_test_5 = (y_test == '9')

Когда вы проверяете с целым числом, все это получает False, и Python предупреждает вас, что у вас есть только 1 класс.

22
задан TRiG 21 March 2017 в 17:04
поделиться

5 ответов

Вам нужно будет сделать вашу функцию нечувствительной к регистру, чтобы получить результат "Hello" => "hello", который вы ищете, попробуйте этот метод:

$arr = array(1=>'1233',2=>'12334',3 =>'Hello' ,4=>'hello', 5=>'U');

// Convert every value to uppercase, and remove duplicate values
$withoutDuplicates = array_unique(array_map("strtoupper", $arr));

// The difference in the original array, and the $withoutDuplicates array
// will be the duplicate values
$duplicates = array_diff($arr, $withoutDuplicates);
print_r($duplicates);

Вывод:

Array
(
[3] => Hello
[4] => hello
)

Edit автор @AlixAxel:

Этот ответ вводит в заблуждение. Он работает только в этом конкретном состоянии. Этот контрпример:

$arr = array(1=>'1233',2=>'12334',3 =>'Hello' ,4=>'HELLO', 5=>'U');

с треском проваливается . Кроме того, это не способ хранить дубликаты:

array_diff($arr, array_unique($arr));

Поскольку одно из дублированных значений будет в array_unique , а затем будет отключено array_diff .

Редактировать @ RyanDay:

Итак, посмотрите ответы @Srikanth или @ Bucabay, которые работают для всех случаев (ищите нечувствительность к регистру в Bucabay), а не только на тестовые данные, указанные в вопросе.

16
ответ дан 29 November 2019 в 03:35
поделиться
<?php
function array_not_unique($raw_array) {
    $dupes = array();
    natcasesort($raw_array);
    reset($raw_array);

    $old_key   = NULL;
    $old_value = NULL;
    foreach ($raw_array as $key => $value) {
        if ($value === NULL) { continue; }
        if (strcasecmp($old_value, $value) === 0) {
            $dupes[$old_key] = $old_value;
            $dupes[$key]     = $value;
        }
        $old_value = $value;
        $old_key   = $key;
    }
    return $dupes;
}

$raw_array    = array();
$raw_array[1] = 'abc@xyz.com';
$raw_array[2] = 'def@xyz.com';
$raw_array[3] = 'ghi@xyz.com';
$raw_array[4] = 'abc@xyz.com'; // Duplicate

$common_stuff = array_not_unique($raw_array);
var_dump($common_stuff);
23
ответ дан 29 November 2019 в 03:35
поделиться

Это правильный способ сделать это (с учетом регистра):

array_intersect($arr, array_unique(array_diff_key($arr, array_unique($arr))));

И решение без учета регистра:

$iArr = array_map('strtolower', $arr);
$iArr = array_intersect($iArr, array_unique(array_diff_key($iArr, array_unique($iArr))));

array_intersect_key($arr, $iArr);

Но @Srikanth ответ более эффективен (на самом деле, это единственный, который работает правильно , кроме этого).

6
ответ дан 29 November 2019 в 03:35
поделиться

Попробуйте:

$arr2 = array_diff_key($arr, array_unique($arr));
<час>

без учета регистра:

array_diff_key($arr, array_unique(array_map('strtolower', $arr)));
3
ответ дан 29 November 2019 в 03:35
поделиться
function array_not_unique($raw_array) {
    $dupes = array();
    natcasesort($raw_array);
    reset($raw_array);

    $old_key   = NULL;
    $old_value = NULL;
    foreach ($raw_array as $key => $value) {
        if ($value === NULL) { continue; }
        if (strcasecmp($old_value, $value) === 0) {
            $dupes[$old_key] = $old_value;
            $dupes[$key]     = $value;
        }
        $old_value = $value;
        $old_key   = $key;
    } return $dupes;
}

What Srikanth (john) добавил, но сравнение без учета регистра.

6
ответ дан 29 November 2019 в 03:35
поделиться
Другие вопросы по тегам:

Похожие вопросы: