繁体   English   中英

在R中的子集数据框中替换多个列值

[英]Replace multiple column values in a subset dataframe in R

我想替换R中的子集数据帧的某些值,例如:

我使用的数据框:

sw1<- swiss[1:5, 1:4]
sw2 <- rbind(sw1,sw1)

这是一些索引标准定义的子集:

sw2[sw2$Examination==15 & sw2$Education==12,]

我想分别将“考试”和“教育”的值分别替换为1和2。 但是,如何为这些单元格分配值,以便获得具有正确值的sw2数据帧。

在您的问题:

sw2 <- rbind(sw2,sw2)

sw2来自哪里? 我只是假设您的rbind()应该是:

sw2 <- rbind(sw1, sw1)

无论如何,您可以像这样替换这两列:

sw2[sw2$Examination==15 & sw2$Education==12, c('Examination', 'Education')]  <- list(1, 2)

我隔离了需要用c('Examination', 'Education')更新的列。 list(1, 2)将自动重复您分配给它的尽可能多的行(在这种情况下为两行)。

语法有点时髦,所以我可能会做更长的时间,但更容易阅读。

m <- with(sw2, Examination == 15 & Education == 12)
sw2[m, 'Examination'] <- 1
sw2[m, 'Education'] <- 2

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM