R语言填补缺失值

使用R语言填补缺失值

数据处理过程中,往往会存在缺失值,对于缺失值的处理,目前各大统计书提出的方法有剔除,用均数填补,用众数填补,采用其他自变量进行回归,推算缺失值进行填补等。在R语言中如何按要求进行填补?下面将介绍如何进行缺失值填补的各种方法

用某特定值替换缺失值

下面这段代码表示使用0填补缺失值,x是需要填补的数据框的某行或某列,如果是其他值,将0改成需要的值即可。

FillNA <- function(x){
  x[is.na(x )]<- 0;
  x
}

使用均值,众数,中位数进行填补

该过程函数是一样的,只需要将后续填补要用的值进行修正即可。

library(data.table)
library(dplyr)
library(tidyverse)

#data.table
setDT(data)
data[,names(data):=lapply(.SD,function(x){x[is.na(x)] <- getmode(x)
x})]

#dplyr
data %>% 
    mutate_all(function(x){x[is.na(x)] <- getmode(x)
    x})
dplyr_if_else      <- function(x) { mutate_all(x, ~if_else(is.na(.), 0, .)) }
#tidyverse
df %>% 
    select(Pclass, Sex, SibSp, Embarked) %>%
    map_dfc(~ replace_na(.x, rstatix::get_mode(.x)[1]))

你可能感兴趣的:(r数据清洗,r语言)