У меня есть таблица данных с 57-м записями и 9 столбцами, одна из которых вызывает проблему, когда я пытаюсь запустить некоторую итоговую статистику. Столбец оскорбления является фактором с 3699 уровнями, и я получаю сообщение об ошибке из следующей строки кода:
> unique(da$UPC)
Error in unique.default(da$UPC): hash table is full
Теперь, очевидно, я бы просто использовал: levels(da$UPC)
, но я пытаюсь подсчитать уникальные значения, которые существуют в каждой группе, как часть нескольких j параметров /caluclations в инструкции группы данных.
Интересно, что unique(da$UPC[1:1000000])
работает как ожидалось, однако unique(da$UPC[1:10000000])
этого не делает. Учитывая, что моя таблица имеет 57-миллиметровые записи, это проблема.
Я попытался преобразовать коэффициент в символ и не работает без проблем:
da$UPC = as.character(levels(da$UPC))[da$UPC]
unique(da$UPC)
Выполнение этого показывает мне дополнительный "уровень", который равен NA
. Так как мои данные имеют некоторые НС в столбце факторов, уникальная функция не работает. Мне интересно, это то, что разработчики знают о чем-то, что нужно исправить? Я нашел следующую статью о r-devel, которая может быть актуальной, но я не уверен, и она не упоминает data.table
.
Связанная статья: уникальная (1: 3, nmax = 1) зависает R!
sessionInfo:
R version 3.0.1 (2013-05-16)
Platform: x86_64-unknown-linux-gnu (64-bit)
locale:
[1] LC_CTYPE=C LC_NUMERIC=C
[3] LC_TIME=en_US.iso88591 LC_COLLATE=C
[5] LC_MONETARY=en_US.iso88591 LC_MESSAGES=en_US.iso88591
[7] LC_PAPER=C LC_NAME=C
[9] LC_ADDRESS=C LC_TELEPHONE=C
[11] LC_MEASUREMENT=en_US.iso88591 LC_IDENTIFICATION=C
attached base packages:
[1] stats graphics grDevices utils datasets methods base
other attached packages:
[1] plyr_1.8 data.table_1.8.8