R распространение нескольких столбцов с помощью tidyr [дубликат]
этот вопрос уже есть ответ здесь:
возьмите этот пример переменной
df <- data.frame(month=rep(1:3,2),
student=rep(c("Amy", "Bob"), each=3),
A=c(9, 7, 6, 8, 6, 9),
B=c(6, 7, 8, 5, 6, 7))
Я могу использовать spread
С tidyr
чтобы изменить это на широкий формат.
> df[, -4] %>% spread(student, A)
month Amy Bob
1 1 9 8
2 2 7 6
3 3 6 9
но как я могу распространять два значения, как, например,A
и B
, таким образом, что выход что-то вроде
month Amy.A Bob.A Amy.B Bob.B
1 1 9 8 6 5
2 2 7 6 7 6
3 3 6 9 8 7
1 ответ:
вот возможное простое и очень эффективное решение с использованием
data.table
library(data.table) ## v >= 1.9.6 dcast(setDT(df), month ~ student, value.var = c("A", "B")) # month Amy_A Bob_A Amy_B Bob_B # 1: 1 9 8 6 5 # 2: 2 7 6 7 6 # 3: 3 6 9 8 7
или
tidyr
решениеdf %>% gather(variable, value, -(month:student)) %>% unite(temp, student, variable) %>% spread(temp, value) # month Amy_A Amy_B Bob_A Bob_B # 1 1 9 6 8 5 # 2 2 7 7 6 6 # 3 3 6 8 9 7