填充索引值上方和下方的选择行

时间:2019-01-27 00:08:49

标签: r for-loop if-statement dplyr fill

在R中工作时遇到问题
我在数据框(df)中有一个变量(X),看起来像这样

df$X
NA
12345
NA
NA
32409
NA
NA
NA
NA
NA
04598
NA
NA
NA

我需要执行以下操作:

如果X不是NA,请替换:
-X中的前一行,其值
-填写其余的行,直到达到下一个值

最终,它应该看起来像这样

df$X
12345
12345
12345
32409
32409
32409
32409
32409
32409
04598
04598
04598
04598
04598

我尝试使用for循环来完成第一部分(在上一行中填充),但似乎无法使它工作

for (x in df$X) {

x = df$X[x]  
y = x -1  
df$X[y] <-  ifelse(!is.na(x), x, NA)

}

非常感谢您的帮助!

1 个答案:

答案 0 :(得分:0)

这是使用dplyrtidyr的方法:

library(dplyr)
df2 <- df %>%
  mutate(X = if_else(is.na(X), lead(X), X)) %>%
  tidyr::fill(X)