如何根据条件在data.frame中创建新变量?

eas*_*fri 15 r dataframe

假设我们有一个数据帧

x   y
1   1
2   4 
4   5 
Run Code Online (Sandbox Code Playgroud)

如何在数据框中添加一个新变量,使得如果x小于或等于1,则返回"good",如果x介于3和5之间,则返回"bad",否则返回"fair"

x   y  w
1   1  "good"
2   2   "fair"
5   5   "bad"
Run Code Online (Sandbox Code Playgroud)

应用了ocram.所示的方法,但是这里的方法不起作用.

d1 <- c("e", "c", "a")
d2 <- c("e", "a", "b")

w <- ifelse(d1 == "e" & (d2=="e"), 1, ifelse((d1 == "a") & (d2 =="b"), 2, ifelse(d1 == "e"),3,99))
Run Code Online (Sandbox Code Playgroud)

有任何想法吗?谢谢

Mar*_*rco 21

一个明显而直接的可能性是使用"if-else条件".在那个例子中

x <- c(1, 2, 4)
y <- c(1, 4, 5)
w <- ifelse(x <= 1, "good", ifelse((x >= 3) & (x <= 5), "bad", "fair"))
data.frame(x, y, w)
Run Code Online (Sandbox Code Playgroud)

**对于编辑中的其他问题**这是您所期望的吗?

> d1 <- c("e", "c", "a")
> d2 <- c("e", "a", "b")
> 
> w <- ifelse((d1 == "e") & (d2 == "e"), 1, 
+    ifelse((d1=="a") & (d2 == "b"), 2,
+    ifelse((d1 == "e"), 3, 99)))
>     
> data.frame(d1, d2, w)
  d1 d2  w
1  e  e  1
2  c  a 99
3  a  b  2
Run Code Online (Sandbox Code Playgroud)

如果您对该ifelse功能感到不舒服,您还可以使用此类应用程序的ifelse语句.