这可能是一个非常简单的问题,但我无法在任何地方找到答案。我有一个基本的数据框:
somedf <- data.frame(ageGroup = c("Under10", "Over10", "Over50", "Over100"),
favColor = c("red", "pink", "purple", "blue"))
ageGroup favColor
1 Under10 red
2 Over10 pink
3 Over50 purple
4 Over100 blue
这有效:
somedf$ageGroup2 <- ifelse(somedf$ageGroup == "Under10", 1, 2 )
ageGroup favColor ageGroup2
1 Under10 red 1
2 Over10 pink 2
3 Over50 purple 2
4 Over100 blue 2
但这不会:
somedf$ageGroup3 <- ifelse(somedf$ageGroup == "Under10" ||
somedf$ageGroup == "Over10" , 3, 4 )
ageGroup favColor ageGroup2 ageGroup3
1 Under10 red 1 3
2 Over10 pink 2 3
3 Over50 purple 2 3
4 Over100 blue 2 3
如您所见,所有行都采用第一行收到的值。我以为您可以进行矢量运算并一次设置整个列的值,ifelse
但是我在这里做错了什么。即使是复杂/嵌套if/else if/else
的语句也会做同样的事情。
谢谢!