全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
1131 1
2015-05-08
悬赏 20 个论坛币 已解决
id t var1  var2
1 1998  2 2
1 1999  2 4
1 2000 3 12
2 1997 2 2
2 1998 . 2
2 1999 4 8

var2是根据id 对var1的累乘
得出每个id的var2 ,如果var1空缺, 就保持上一个var2

最佳答案

缘oO来如此0o 查看完整内容

data var; input id year var1; cards; 1 1998 2 1 1999 2 1 2000 3 2 1997 2 2 1998 . 2 1999 4 ;run; data want; retain var2; set var; by id; if first.id then do ; if not missing(var1) then var2=var1; else var2=1; end; else if not missing(var1) then var2=var1*var2; run;
二维码

扫码加我 拉你入群

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

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

全部回复
2015-5-8 11:04:13
data var;
input id year var1;
cards;
1 1998  2
1 1999  2
1 2000 3
2 1997 2
2 1998 .
2 1999 4
;run;


data want;
        retain var2;
        set var;
        by id;
        if first.id then do ;
                if not missing(var1) then var2=var1;
                else var2=1;
        end;
        else if not missing(var1) then var2=var1*var2;
run;
二维码

扫码加我 拉你入群

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

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

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

说点什么

分享

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