remove row with nan value

后端 未结 2 424
悲哀的现实
悲哀的现实 2020-12-13 18:56

let\'s say, for example, i have this data:

data <- c(1,2,3,4,5,6,NaN,5,9,NaN,23,9)
attr(data,\"dim\") <- c(6,2)
data

     [,1] [,2]
[1,]    1  NaN
[2,         


        
相关标签:
2条回答
  • 2020-12-13 19:30

    The function complete.cases will tell you where the rows are that you need:

    data <- matrix(c(1,2,3,4,5,6,NaN,5,9,NaN,23,9), ncol=2)
    data[complete.cases(data), ]
    
         [,1] [,2]
    [1,]    2    5
    [2,]    3    9
    [3,]    5   23
    [4,]    6    9
    
    0 讨论(0)
  • 2020-12-13 19:30

    DATA

    data <- matrix(rnorm(100000000), ncol=10000)
    idx <- sample(1:10000,100)
    idy <- sample(1:10000,100)
    data[idx,idy] <- NaN
    

    FUNCTION

    foo <- function(d=data) d[apply(d,2,function(x) any(is.nan(x))),]
    

    RUNTIMES

    > system.time(data[complete.cases(data),])
       user  system elapsed 
       3.53    0.12    3.65 
    
    > system.time(foo(data))
       user  system elapsed 
       2.37    0.09    2.46 
    
    0 讨论(0)
提交回复
热议问题