我有两个数据框,logger 和 df(时间是数字):
logger <- data.frame(
time = c(1280248354:1280248413),
temp = runif(60,min=18,max=24.5)
)
df <- data.frame(
obs = c(1:10),
time = runif(10,min=1280248354,max=1280248413),
temp = NA
)
我想在 logger$time 中搜索与 df$time 中每一行最接近的匹配项,并将关联的 logger$temp 分配给 df$temp。到目前为止,我已经成功使用以下循环:
for (i in 1:length(df$time)){
closestto<-which.min(abs((logger$time) - (df$time[i])))
df$temp[i]<-logger$temp[closestto]
}
但是,我现在有很大的数据帧(记录器有 13,620 行,df 有 266138 行)并且处理时间很长。我读过循环不是最有效的做事方式,但我不熟悉替代方案。有没有更快的方法来做到这一点?