我有气象站和发生频率的应急表。我使用逻辑索引从表中创建了如下所示的独立向量(b1:b5)。然而,必须有一个更简单的方法,也许来自申请家庭。有人能举个这样的例子吗,谢谢。
mf1<-c("USW00023047","USW00013966","USC00416740","USC00413828", "USC00414982", "USC00414982", "USW00013966", "USW00013966", "USW00003927",
"USW00003927", "USC00412019", "USC00411596", "USW00012960", "USW00012960", "USW00012960", "USW00012960", "USW00012960", "USC00417327",
"USC00417327", "USC00418433", "USC00417743", "USC00419499", "USC00419847", "USR0000TCLM", "USR0000TCOL", "USW00012921", "USW00012921",
"USW00012970", "USW00012921", "USW00012921", "USW00012924")
table(mf1)
dfcont<-as.data.frame(table(mf1))
a<-dfcont$mf1
b1<-a[dfcont$Freq < 6]
b2<-a[dfcont$Freq == 2]
b3<-a[dfcont$Freq == 3]
b4<-a[dfcont$Freq == 4]
b5<-a[dfcont$Freq == 5]发布于 2020-06-27 03:14:45
您可以使用split
temp <- split(as.character(dfcont$mf1), dfcont$Freq)这将给出temp中向量的列表。通常,最好将数据保存在一个列表中,但是如果您希望将数据作为单独的向量分配给它们并使用list2env
names(temp) <- paste0('b', seq_along(temp))
list2env(temp, .GlobalEnv)您现在可以在您的全球环境中使用b1、b2等。
发布于 2020-06-27 03:59:34
我找不到比
tbl <- table(mf1)
split(names(tbl), tbl)如果名称需要为b*,则通过粘贴"b"作为当前名称的前缀来分配。
names(sp) <- paste0('b', names(sp))https://stackoverflow.com/questions/62605398
复制相似问题