【发布时间】:2020-12-30 13:48:17
【问题描述】:
我有一个时间序列数据框,想创建一个新的数值列,其值是现有数值列的函数,并根据星期几列分配。
例如,我需要如下代码:
Day <- c("Mo", "Mo", "Mo", "Tu", "Tu", "We", "We", "We", "We", "Th")
Val <- c(1000, 1000, 1000, 1000, 1000, 1000, 1000, 1000, 1000, 1000)
df <- data.frame(cbind(Day,Val))
df$Adj <- ifelse(df$Day == "Mo" || df$Day == "Tu",
as.numeric(levels(df$Val)) + 1,
as.numeric(levels(df$Val)) + 2)
返回:
Day Val Adj
1 Mo 1000 1001
2 Mo 1000 1001
3 Mo 1000 1001
4 Tu 1000 1001
5 Tu 1000 1001
6 We 1000 1002
7 We 1000 1002
8 We 1000 1002
9 We 1000 1002
10 Th 1000 1002
不幸的是,我的代码仅将 Adj 作为 1001 列返回。
Day Val Adj
1 Mo 1000 1001
2 Mo 1000 1001
3 Mo 1000 1001
4 Tu 1000 1001
5 Tu 1000 1001
6 We 1000 1001
7 We 1000 1001
8 We 1000 1001
9 We 1000 1001
10 Th 1000 1001
我已经在 "We" 行之一上测试了 ifelse,它成功了……
> ifelse(df$Day[6] == "Mo" || df$Day[6] == "Tu",
+ as.numeric(levels(df$Val[6])) + 1,
+ as.numeric(levels(df$Val[6])) + 2)
[1] 1002
...但我似乎无法让它在整个列上工作,我理解这是 ifelse 函数相对于循环 if-else 语句的优势之一。
我的方法基于我能找到的最相似的问题 (Create new column in dataframe using if {} else {} in R) 但没有快乐。我在这里错过了什么?
【问题讨论】:
-
首先,将
stringsAsFactors = TRUE添加到data.frame()中(在最新的R 版本中,stringsAsFactors默认为FALSE)。然后将||替换为|,你的代码就可以工作了!
标签: r if-statement dplyr