10832 12

[问答] 如何给某列缺失值填补该类的平均值,在不采用其他扩展包的情况下。 [推广有奖]

  • 8关注
  • 1粉丝

博士生

78%

还不是VIP/贵宾

-

威望
0
论坛币
436 个
通用积分
0.0602
学术水平
5 点
热心指数
5 点
信用等级
0 点
经验
4549 点
帖子
164
精华
0
在线时间
407 小时
注册时间
2015-11-3
最后登录
2020-2-8

楼主
露露的家园2012 发表于 2018-8-5 20:43:45 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
因为环境的限制,R上处理本身自带有的包,还有以下包,其他扩展包没有的情况下:
1.jpg
想要对某列缺失值填补该列的平均值;
比如数据框dt,
a<-c(1,2,3)
b<-c(1,NA,NA)
c<-c(2,NA,4)
d<-data.frame(a,b,c)
d
  a b c
  1 1 2
  2 NA NA
  3 NA 4
问题:想要将c列的NA值用c列的平均值代替;b列的用b列平均值代替;怎么做?
如果用:
dt[is.na(dt)]<-mean(dt$列名,na.rm=T)只能用某列的平均值代替所有的NA,这样是不准确的?在已有的情况下有没有办法?
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:缺失值填补 缺失值 平均值

回帖推荐

cheetahfly 发表于3楼  查看完整内容

dt$列名

nuomin 发表于4楼  查看完整内容

colMeans函数就可以

沙发
chenyihui 在职认证  发表于 2018-8-5 21:35:22
简单的问题用简单的工具。SPSS就很容易实现。

藤椅
cheetahfly 在职认证  发表于 2018-8-5 21:37:00
dt$列名[is.na(dt$列名)] <- mean(dt$列名,na.rm = TRUE)

板凳
nuomin 发表于 2018-8-5 21:42:35
colMeans函数就可以

报纸
露露的家园2012 发表于 2018-8-6 10:06:41
nuomin 发表于 2018-8-5 21:42
colMeans函数就可以
d[is.na(d)]<-colMeans(d,na.rm=T)
谢谢,可以了

地板
露露的家园2012 发表于 2018-8-6 10:09:00
cheetahfly 发表于 2018-8-5 21:37
dt$列名
谢谢,试了一下,你这个语句也是可以的。
d$b[is.na(d$b)]<-mean(d$b,na.rm=T)

7
露露的家园2012 发表于 2018-8-6 10:09:02
cheetahfly 发表于 2018-8-5 21:37
dt$列名
谢谢,试了一下,你这个语句也是可以的。
d$b[is.na(d$b)]<-mean(d$b,na.rm=T)

8
nuomin 发表于 2018-8-6 10:19:12
你是程序员吧?

9
露露的家园2012 发表于 2018-8-6 10:29:42
nuomin 发表于 2018-8-6 10:19
你是程序员吧?
不是不是

10
ghewui 发表于 2020-6-9 18:55:25
露露的家园2012 发表于 2018-8-6 10:06
d
谢谢谢谢谢谢谢

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-25 09:09