首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >均值返回NaN除了na.rm= TRUE

均值返回NaN除了na.rm= TRUE
EN

Stack Overflow用户
提问于 2016-02-15 15:11:33
回答 1查看 9.5K关注 0票数 5

样本数据

代码语言:javascript
复制
date        coins   
2013-10-01  NA      
2013-10-01  NA      
2013-10-01  NA      
2013-11-01  10      
2013-11-01  NA      
2013-11-01  20      
2013-11-01  30      
2013-11-01  40      
2013-12-30  NA      
2013-12-30  22      
2013-12-30  24
2013-12-30  25

我想做什么?

我想计算硬币列的平均值和中位数,忽略缺失的值。

到目前为止我做了什么?

  1. 将日期变量by_date <- group_by(df, date)上的数据分组
  2. 摘要数据使用:by_date %>% summarise_each_(funs(mean(., na.rm = TRUE), median(., na.rm=TRUE)), names(by_date)[2])

问题 summarise_each_返回的结果显示NaN for date 2013-10-01.这是否意味着函数没有忽略缺少的值?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-02-15 15:51:34

这里的问题是,2013-10-01年的所有值都是NA,所以不可能有一个平均值。NaN正试图告诉你这个。

如果您不希望在摘要中显示2013-10-01,那么可以选择如下所示的预先删除NA值:

代码语言:javascript
复制
by_date<-group_by(df[!is.na(df$coins),],date)
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35412784

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档