我有一个这样的数据框-
uniq = data.frame(Freq = c(172,4,50,3),
seq = c("G","G G T G T","G G T T","T G T T A T T"))
我想将第二列拆分为多个列,而无需重复。 字符串之间用空格隔开。
我尝试使用下面的代码,但这会将值从较小的字符串复制到较长的字符串的长度-
within(uniq, uniq_seq <-data.frame(do.call('rbind', strsplit(as.character(uniq[,2]), ' '))))
感谢您的帮助!
答案 0 :(得分:2)
绝对是一个奇怪的请求,但使用 tidyverse 绝对可能。
library(tidyverse)
df <- uniq %>%
mutate(n = row_number()) %>%
separate_rows(seq, sep = ' ') %>%
group_by(n, Freq) %>%
mutate(n2 = row_number()) %>%
spread(n2, seq) %>%
select(-n)
Freq `1` `2` `3` `4` `5` `6` `7`
<dbl> <chr> <chr> <chr> <chr> <chr> <chr> <chr>
1 3 T G T T A T T
2 4 G G T G T NA NA
3 50 G G T T NA NA NA
4 172 G NA NA NA NA NA NA