全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
1364 3
2016-12-26
悬赏 50 个论坛币 未解决

复制代码


每个个体的值y计算如下:
0.5*(visit=1的x值+visit=2的x值)+0.5*(visit=2的x值+visit=3的x值)+0.5*(visit=3的x值+visit=4的x值)+0.5*(visit=4的x值+visit=5的x值)

最终希望得到的数据
id y
1  
2  值
3  
或者
id visit x y
1 1 3  .
1 2 3 .
1 3 2 .
1 4 1 .
1 5 0  值
2 1 2 .
2 2 2 .
2 3 1 .
2 4 0 .
2 5 0
3 1 1 .
3 2 1 .
3 3 1 .
3 4 0 .
3 5 0 .

谢谢!
二维码

扫码加我 拉你入群

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

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

全部回复
2016-12-26 12:19:06
proc sort data=aaa out=aaa1;
by id visit;
run;

data wanted;
set aaa1;
by id visit;
lagx=lag(x);
if first.id then call missing(lagx);
if lagx ne . then mean=mean(x,lagx);
if first.id then y=0;
  y+mean;
if last.id;
keep id y;
run;
二维码

扫码加我 拉你入群

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

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

2016-12-26 13:41:11
proc sort data=aaa;
by id;
run;
data b;
set aaa;
by id;
if first.id then temp=0.5*x;
else if last.id then temp=0.5*x;
else temp=x;
run;
proc sql;
create table total as
select id,sum(temp) as y
  from b
   group by id ;
  quit;

最后的total就是你想要的结果
二维码

扫码加我 拉你入群

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

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

2016-12-28 21:55:45
方法太多了
二维码

扫码加我 拉你入群

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

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

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

说点什么

分享

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