【发布时间】:2018-05-10 12:19:34
【问题描述】:
我想让我的代码更高效,我有一个调查,我的数据如下所示:
survey <- data.frame(
x = c(1, 6, 2, 60, 75, 40, 27, 10),
y = c(100, 340, 670, 700, 450, 200, 136, 145))
#Two lists:
A <- c(3, 6, 7, 27, 40, 41)
t <- c(0.10, 0.11, 0.12, 0.13, 0.14, 0.15, 0.16)
我所做的是创建新列,如下所示:
z <- ifelse(survey$x %in% A), 0, min(t))
for (i in t) {
survey[paste0("T",i)] <-z
survey[paste0("T",i)] <-ifelse (z > 0, i, z)
}
但是使用该代码需要一段时间,有没有更好的方法来做到这一点?
【问题讨论】:
-
你可以做
survey[paste0("T", t)] <- lapply(t, function(y) ifelse(survey$x %in% A, 0, y)) -
您也可以查看
data.table,这可能更快,即setDT(survey)[, paste0("T", t) := 0]; for(j in t) { set(survey, i = which(!survey$x %in% A), j = paste0("T", j), value = j)}
标签: r loops if-statement dataframe survey