相关文章推荐
幸福的草稿本  ·  【每周经济观察】夯实经济企稳向好基础_中国经 ...·  8 月前    · 
发呆的人字拖  ·  TrendForce:全球前五大SSD模組廠 ...·  9 月前    · 
豪气的煎鸡蛋  ·  Python进阶06 循环对象 - ...·  11 月前    · 
旅途中的小马驹  ·  作势:今夜我愿化作一只盯裆猫|盯裆猫|吴亦凡 ...·  1 年前    · 
发财的李子  ·  结构工程师-天津锘华仪器科技有限公司·  1 年前    · 
Code  ›  R语言中的特殊值及缺失值NA的处理方法开发者社区
r语言 finite
https://cloud.tencent.com/developer/article/2218248
谦虚好学的毛衣
2 年前
作者头像
小汪Waud
0 篇文章

R语言中的特殊值及缺失值NA的处理方法

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP
返回腾讯云官网
社区首页 > 专栏 > 小汪Waud > R语言中的特殊值及缺失值NA的处理方法

R语言中的特殊值及缺失值NA的处理方法

作者头像
小汪Waud
发布 于 2023-02-16 16:50:10
530 0
发布 于 2023-02-16 16:50:10
举报

R语言中存在一些null-able values,当我们进行数据分析时,理解这些值是非常重要的。

通常来说,R语言中存在:

  • NA
  • NULL
  • NaN
  • Inf/-Inf

这四种数据类型在R中都有相应的函数用以判断。

NA

NA即Not available,是一个 长度为1的逻辑常数 ,通常代表缺失值。NA可以被强制转换为任意其他数据类型的向量。

> a <- NA
> class(a)
[1] "logical"
> length(a)
[1] 1

可以采用is.na()进行判断。另外,NA和“NA”不可以互换。

NULL

NULL是一个 对象(object) ,当 表达式或函数产生无定义的值 或者 导入数据类型未知的数据 时就会返回NULL。

> b <- NULL
> class(b)
[1] "NULL"
> length(b)
[1] 0

可以采用is.null()进行判断。

NaN

NaN即Not A Number,是一个 长度为1的逻辑值向量 。

> c <- NaN
> class(c)
[1] "numeric"
> length(c)
[1] 1
> is.finite(c)
[1] FALSE

可以采用is.nan()进行判断。另外,我们可以采用is.finite()或is.infinite()函数来判断元素是有限的还是无限的,而对NaN进行判断返回的结果都是False。

Inf/-Inf

Inf即Infinity无穷大,通常代表一个很大的数或 以0为除数的运算结果 ,Inf说明数据并没有缺失(NA)。

> d <- Inf
> class(d)
[1] "numeric"
> length(d)
[1] 1

可以采用is.finite()或is.finite()进行判断。

缺失值NA的处理

理解完四种类型数值以后,我们来看看该采取什么方法来处理最常见的缺失值NA。

小白学统计在推文 《有缺失值怎么办?系列之二:如何处理缺失值》 里说“ 处理缺失值最好的方式是什么?答案是:没有最好的方式。或者说,最好的方式只有一个,预防缺失,尽量不要缺失。 ”

1 直接删除法

在缺失数很少且数据量很大的时候,直接删除法的效率很高,而且通常对结果的影响不会太大。

如数据框df共有1000行数据,有10行包含NA,不妨直接采用函数na.omit()来去掉带有NA的行,也可以使用tidyr包的drop_na()函数来指定去除哪一列的NA。

drop_na(df,X1) # 去除X1列的NA

2 填充法

用其他数值填充数据框中的缺失值NA。

2.1 df[is.na(df)]
df[is.na(df)] = 0
 
推荐文章
幸福的草稿本  ·  【每周经济观察】夯实经济企稳向好基础_中国经济网——国家经济门户
8 月前
发呆的人字拖  ·  TrendForce:全球前五大SSD模組廠通路市占續升,中國品牌享主場優勢
9 月前
豪气的煎鸡蛋  ·  Python进阶06 循环对象 - Vamei - 博客园
11 月前
旅途中的小马驹  ·  作势:今夜我愿化作一只盯裆猫|盯裆猫|吴亦凡|张继科_新浪时尚_新浪网
1 年前
发财的李子  ·  结构工程师-天津锘华仪器科技有限公司
1 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号