Я хочу изменить столбец в моей data.table с помощью dcast, но я не хочу, когда это двоичные значения (0/1) или когда нет в уровнях
, например, эта data.table:
dt1 <- data.table::data.table("ID" = 1:4,'Col0' = c(1, 0, 1, 0),'Col1' = c('a', 'b', 'c', 'a'),'Col2' = (letters[20:23]),'Col3' = factor(c("a", "b", NA, "a"),levels = c("a", "b", "c")))
Я добавляю ID раньше для try dcast, но мы можем переместить это значение
Я пробовал это сделать, но, как и раньше, описываю, прежде чем возникнут проблемы с уровнями и двоичным кодом.
res = data.table::dcast(data.table::melt(dt1, id.vars='ID'), ID ~ variable + value, fun = length)
Я пытался получить этот результат.
result <- data.table::data.table('Col0' = c(1, 0, 1, 0),'Col1_a' = c(1, 0, 0, 1),'Col1_b' = c(0, 1, 0, 0),'Col1_c' = c(0, 0, 1, 0),'Col2_t' = c(1, 0, 0, 0),'Col2_u' = c(0, 1, 0, 0),'Col2_v' = c(0, 0, 1, 0),'Col2_w' = c(0, 0, 0, 1), 'Col3_a' = c(1, 0, NA, 1),'Col3_b' = c(0, 1, NA, 0))