楼主: 后街厨子
1672 11

[原创博文] 请教大家解决个问题 [推广有奖]

  • 0关注
  • 0粉丝

初中生

4%

还不是VIP/贵宾

-

威望
0
论坛币
0 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
58 点
帖子
8
精华
0
在线时间
11 小时
注册时间
2012-2-15
最后登录
2016-8-21

相似文件 换一批

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
用data步 给出各股票最后2日的收盘价。
60000 2002-01-04 15.01
60000 2002-01-05 12.01
60000 2002-01-06 13.01
60000 2002-01-07 14.01
60000 2002-01-08 14.01
60011 2002-01-04 15.01
60011 2002-01-05 12.01
60011 2002-01-06 13.01
60011 2002-01-07 14.01
60011 2002-01-08 14.01
60022 2002-01-04 15.01
60022 2002-01-05 12.01
60022 2002-01-06 13.01
60022 2002-01-07 14.01
60022 2002-01-08 14.01
二维码

扫码加我 拉你入群

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

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

关键词:data步 Data 收盘价 收盘价

沙发
后街厨子 发表于 2012-2-19 23:58:48 |只看作者 |坛友微信交流群
坐等高手解惑

使用道具

藤椅
xucp 发表于 2012-2-20 00:04:03 |只看作者 |坛友微信交流群
把你这个文件给我,我试试

使用道具

板凳
后街厨子 发表于 2012-2-20 00:08:53 |只看作者 |坛友微信交流群
xucp 发表于 2012-2-20 00:04
把你这个文件给我,我试下
谢谢啦

test.zip

3.07 MB

本附件包括:

  • test.sas7bdat

使用道具

报纸
wh_wing 发表于 2012-2-20 09:37:17 |只看作者 |坛友微信交流群
U can try this!
  1. data a;
  2. input ID $ time yymmdd10. price;
  3. cards;
  4. 60000 2002-01-04 15.01
  5. 60000 2002-01-05 12.01
  6. 60000 2002-01-06 13.01
  7. 60000 2002-01-07 14.01
  8. 60000 2002-01-08 14.01
  9. 60011 2002-01-04 15.01
  10. 60011 2002-01-05 12.01
  11. 60011 2002-01-06 13.01
  12. 60011 2002-01-07 14.01
  13. 60011 2002-01-08 14.01
  14. 60022 2002-01-04 15.01
  15. 60022 2002-01-05 12.01
  16. 60022 2002-01-06 13.01
  17. 60022 2002-01-07 14.01
  18. 60022 2002-01-08 14.01
  19. ;
  20. data c;
  21. set a;
  22. where time='07JAN2002'd or time='08JAN2002'd;
  23. format time yymmdd10.;
  24. run;
  25. proc print data=c ; run;
复制代码

使用道具

地板
yunqingwang 在职认证  发表于 2012-2-20 09:41:10 |只看作者 |坛友微信交流群
wh_wing 发表于 2012-2-20 09:37
U can try this!
hardcoding

使用道具

7
后街厨子 发表于 2012-2-20 12:59:32 |只看作者 |坛友微信交流群
wh_wing 发表于 2012-2-20 09:37
U can try this!
谢谢你 但如果数据量比较大 日期时间差异较大的话 怎么处理

使用道具

8
可~乐 发表于 2012-2-20 13:45:53 |只看作者 |坛友微信交流群
  1. data a;
  2. input ID $ time yymmdd10. price;
  3. cards;
  4. 60000 2002-01-04 15.01
  5. 60000 2002-01-05 12.01
  6. 60000 2002-01-06 13.01
  7. 60000 2002-01-07 14.01
  8. 60000 2002-01-08 14.01
  9. 60011 2002-01-04 15.01
  10. 60011 2002-01-05 12.01
  11. 60011 2002-01-06 13.01
  12. 60011 2002-01-07 14.01
  13. 60011 2002-01-08 14.01
  14. 60022 2002-01-04 15.01
  15. 60022 2002-01-05 12.01
  16. 60022 2002-01-06 13.01
  17. 60022 2002-01-07 14.01
  18. 60022 2002-01-08 14.01
  19. ;
  20. run;

  21. proc sort data=a;
  22.         by id descending time;
  23. run;

  24. data b;
  25.         set a;
  26.         by id;
  27.                 if first.id then n=1;
  28.                 else n+1;
  29.                 if n<=2 then output;
  30.         format time yymmdd10.;
  31. run;

  32. proc sort data=b;
  33.         by id time;
  34. run;
复制代码
已有 1 人评分学术水平 热心指数 信用等级 收起 理由
zhangzachary + 1 + 1 + 1 精彩帖子

总评分: 学术水平 + 1  热心指数 + 1  信用等级 + 1   查看全部评分

使用道具

9
可~乐 发表于 2012-2-20 14:05:46 |只看作者 |坛友微信交流群
可~乐 发表于 2012-2-20 13:45
数据量大的话,常排序也是个问题,期待更好的方法。。

使用道具

10
wh_wing 发表于 2012-2-20 20:24:35 |只看作者 |坛友微信交流群
如果用sql会好些么?

使用道具

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

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-5-1 05:26