如何使用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语言填补缺失值内容请搜索编程宝库以前的文章,希望大家多多支持编程宝库

在R语言默认目录下有一文件夹test,其下有三个文件,分别是test1.txt, text2.txt, text3.txt,现在要对这三个文件进行批量的修改。主要使用到了for循环和sub()字符替换函数。思路 ...