我有一个包含一些事件日期的数据框。
我使用difftime来计算每个事件之间的延迟,但现在我想为每个第一个事件创建一个因子。
这是我的尝试:
dataframe$delay.event.A = difftime(dataframe$dateA, dataframe$dateStart, units = "days")
dataframe$delay.event.B = difftime(dataframe$dateB, dataframe$dateStart, units = "days")
dataframe$delay.event.C = difftime(dataframe$dateC, dataframe$dateStart, units = "days")
dataframe$delay.first.event = pmin.int(dataframe$delay.event.A, dataframe$delay.event.B, dataframe$delay.event.C, na.rm = TRUE)
dataframe$event.status = ifelse(
dataframe$delay.first.event==dataframe$delay.event.A, "event A", ifelse(
dataframe$delay.first.event==dataframe$delay.event.B, "event B", ifelse(
dataframe$delay.first.event==dataframe$delay.event.C, "event C" , "no event"
)))
这根本不起作用,就像每个ifelse都覆盖了前一个。
我该怎么做?
答案 0 :(得分:1)
这样的事情可能会让你得到你想要的东西。
library(dplyr)
dataframe <- dataframe %>%
mutate(event.status = case_when(.$first.event == .$delay.event.A
~ "event A",
.$first.event == .$delay.event.B
~ "event B",
.$first.event == .$delay.event.C
~ "event C",
TRUE
~ "no event"
)
)