0

这可能是一个非常简单的问题,但我无法在任何地方找到答案。我有一个基本的数据框:

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的语句也会做同样的事情。

谢谢!

4

0 回答 0