Метки из набора данных MNIST в sklearn
содержат строки, а не целые числа. Итак, установите
y_train_5 = (y_train == '9')
y_test_5 = (y_test == '9')
Когда вы проверяете с целым числом, все это получает False
, и Python предупреждает вас, что у вас есть только 1 класс.
Вам нужно будет сделать вашу функцию нечувствительной к регистру, чтобы получить результат "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), а не только на тестовые данные, указанные в вопросе.
<?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);
Это правильный способ сделать это (с учетом регистра):
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 ответ более эффективен (на самом деле, это единственный, который работает правильно , кроме этого).
Попробуйте:
$arr2 = array_diff_key($arr, array_unique($arr));
<час> без учета регистра:
array_diff_key($arr, array_unique(array_map('strtolower', $arr)));
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) добавил, но сравнение без учета регистра.