繁体   English   中英

从上一个非NA值获取索引

[英]Get index from last previous non-NA value

我有这个载体

set.seed(234)
x <- sample(c(rep(NA,3),1:5))
x
[1]  3  5 NA  1  4 NA NA  2

对于每个NA ,我想要最后一个非NA值的索引(或值)。 也就是说,对于第一个NA ,最后一个非NA具有索引2.对于接下来的两个NA ,它们的最后一个非NA具有索引5:

[1]  NA  NA 2  NA  NA 5 5  NA

Base Rtidyverse就可以了。 我尝试了lagleadrleglcoalesce ,但都没有成功。 例如,这非常接近,但仍然是错误的。

a <- rle(is.na(x))
rep(1:length(a$lengths), a$lengths)
[1] 1 1 2 3 3 4 4 5

使用基数R.

y=1:length(x)
y[is.na(x)]=0
y=cummax(y)
y[!is.na(x)]=NA

y
[1] NA NA  2 NA NA  5  5 NA

Henrik挤到one_line

replace(cummax(seq_along(x) * !is.na(x)), !is.na(x), NA)

这是一种通过tidyr函数fill来获取值的方法

library(tidyr)
fill(as.data.frame(x),x)[is.na(x),]
#[1] 5 4 4

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM