楼主: 近暮_妱
5392 3

[问答] sas如何在每天第一行和最后一行添加一行数据 [推广有奖]

  • 0关注
  • 0粉丝

初中生

76%

还不是VIP/贵宾

-

威望
0
论坛币
1531 个
通用积分
0.1500
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
110 点
帖子
4
精华
0
在线时间
24 小时
注册时间
2014-11-2
最后登录
2025-9-17

楼主
近暮_妱 发表于 2014-11-12 20:12:35 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
各位大神,问个问题,sas中要在每天第一行和最后一行添加一行数据,时间变量分别等于00:00:00和23:59:59,价格变量分别等于第二行和倒数第二行,这个应该怎么写啊?一共429天。
二维码

扫码加我 拉你入群

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

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

关键词:时间变量 如何 倒数

沙发
mingfeng07 学生认证  发表于 2014-11-13 00:50:44
举个例子:
  1. data a;
  2. input day time value;
  3. cards;
  4. 1 0 2
  5. 1 1 3
  6. 1 2 8
  7. 1 3 9
  8. 2 0 9
  9. 2 1 8
  10. 2 2 7
  11. 2 3 2
  12. ;
  13. run;
  14. proc sort data=a;by day descending time;
  15. run;
  16. data a(drop=new_value);
  17. set a;
  18. by day descending time;
  19. new_value=lag(value);
  20. if last.day  then value=new_value;
  21. run;
  22. proc sort data=a; by day time;
  23. run;
  24. data a(drop=new_value);
  25. set a;
  26. by day time;
  27. new_value=lag(value);
  28. if last.day then value=new_value;
  29. run;
复制代码

藤椅
pobel 在职认证  发表于 2014-11-13 09:39:39
data wanted;
   set have;
   by date time;
   if first.date then do;
          output;
          time=0; output;
    end;
    if last.date then do;
         output;
         time="23:59:59"t; output;
    end;
run;

板凳
yongyitian 发表于 2014-11-13 10:34:39
  1. proc sort data=have; by date time;
  2. run;

  3. data wanted;
  4.   set have;
  5.   format time time8.;
  6.    by date;
  7.    if first.date then do;
  8.      tmp_time = time;
  9.          time = 0;
  10.      output;
  11.          time = tmp_time; output;
  12.       end;
  13.    else output;
  14.    if last.date then do;
  15.      time="23:59:59"t; output;
  16.    end;
  17.    drop tmp_time;
  18. run;
复制代码

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

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