楼主: luckycai
3137 5

缺失值替换 [推广有奖]

  • 0关注
  • 0粉丝

本科生

2%

还不是VIP/贵宾

-

威望
0
论坛币
400 个
通用积分
0
学术水平
1 点
热心指数
1 点
信用等级
1 点
经验
513 点
帖子
57
精华
0
在线时间
43 小时
注册时间
2010-3-6
最后登录
2016-1-2

楼主
luckycai 在职认证  发表于 2012-6-9 13:00:39 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
想要将缺失值替换为上一个未缺失值,如下:

data a;
input a;
cards;
3
.
4
.
.
5
;
想得到的效果是a 变成
3
3
4
4
4
5
因此编写程序为:
data aa;
set a;
if a=. then a=lag(a);
run;
但是出来的数据集aa与原来的data a相比没有变化,请问大家哪里出问题了哩?

二维码

扫码加我 拉你入群

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

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

关键词:缺失值 cards Input Data card 编写程序

沙发
luckycai 在职认证  发表于 2012-6-9 13:23:52
有个很笨的方法
data aa;
set a;
b=lag(a);
if a=.  then a=b;
run;

但是在我要处理的样本中连续缺失值的个数是不一定的,而且样本量特别大,所以不适宜使用啊
坐等高手指教,,,,
谢谢大家啦。。。。

藤椅
tj0412ymy 发表于 2012-6-9 14:59:20
Lag Function should be outside of If-else condition when imputing missing values. Such like this:
  1. data a;
  2. input x;
  3. cards;
  4. 3
  5. .
  6. 4
  7. .
  8. .
  9. 5
  10. ;
  11. run;

  12. data aa(drop=temp);
  13. set a;
  14. temp=lag(x);
  15. if x=. then x=temp;
  16. run;
  17. proc print noobs;run;
复制代码
对SAS和统计方面感兴趣的朋友,请加SAS学习和认证讨论群:169157207。欢迎在群上讨论!

板凳
tj0412ymy 发表于 2012-6-9 15:06:19
luckycai 发表于 2012-6-9 13:23
有个很笨的方法
data aa;
set a;
The answer you wanted:
  1. data a;
  2. input x;
  3. cards;
  4. 3
  5. .
  6. 4
  7. .
  8. .
  9. 5
  10. 6
  11. .
  12. .
  13. .
  14. 7
  15. ;
  16. run;

  17. data aa(drop=c);
  18. retain c;
  19. set a;
  20. if x<>. then do;
  21. c=x;x=x;
  22. end;
  23. if x=. then x=c;
  24. run;
  25. proc print noobs;run;
复制代码
对SAS和统计方面感兴趣的朋友,请加SAS学习和认证讨论群:169157207。欢迎在群上讨论!

报纸
luckycai 在职认证  发表于 2012-6-9 16:22:48
tj0412ymy 发表于 2012-6-9 15:06
The answer you wanted:
非常感谢!!!

地板
独倚清莲 发表于 2016-3-7 15:38:16
tj0412ymy 发表于 2012-6-9 15:06
The answer you wanted:
厉害!谢谢你

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-4 04:45