全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
3053 5
2012-06-09
想要将缺失值替换为上一个未缺失值,如下:

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相比没有变化,请问大家哪里出问题了哩?

二维码

扫码加我 拉你入群

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

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

全部回复
2012-6-9 13:23:52
有个很笨的方法
data aa;
set a;
b=lag(a);
if a=.  then a=b;
run;

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

扫码加我 拉你入群

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

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

2012-6-9 14:59:20
Lag Function should be outside of If-else condition when imputing missing values. Such like this:
复制代码
二维码

扫码加我 拉你入群

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

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

2012-6-9 15:06:19
luckycai 发表于 2012-6-9 13:23
有个很笨的方法
data aa;
set a;
The answer you wanted:
复制代码
二维码

扫码加我 拉你入群

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

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

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:
厉害!谢谢你
二维码

扫码加我 拉你入群

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

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

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群