楼主: iittala
2547 5

请问各位如何SAS里求股票指数的均线啊,弄了好久了... [推广有奖]

  • 0关注
  • 0粉丝

大专生

11%

还不是VIP/贵宾

-

威望
0
论坛币
1845 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
432 点
帖子
30
精华
0
在线时间
23 小时
注册时间
2013-5-16
最后登录
2021-9-12

50论坛币
请问如何求每日前N天的收盘价的平均值啊?就比如9月16日这一天求7月16号到9月16号所有的收盘价的平均数,然后到了9.17就求7.17到9.17的所有收盘价的平均值,以此类推(也就是60日均线的值)。我用了数组、宏、lag+宏变量试了好久都没能实现。哪位大牛能帮忙写个举例的语句啊,谢谢了!

关键词:股票指数 收盘价 平均值 lag 平均数 SAS 均线 平均 循环 lag
沙发
teqel 发表于 2015-9-16 22:06:10 |只看作者 |坛友微信交流群
  1. proc sql;
  2. create table Smooth_stk as
  3. select a.stk, a.date, (b.price) as Ave_price
  4. from Stock as A left join Stock as B
  5. on a.stk=b.stk and b.date between a.date-60 and a.date
  6. group by a.stk, a.date;
  7. quit;
复制代码

使用道具

藤椅
teqel 发表于 2015-9-16 22:08:39 |只看作者 |坛友微信交流群
select a.stk, a.date, avg(b.price) as Ave_price

使用道具

板凳
teqel 发表于 2015-9-16 22:09:13 |只看作者 |坛友微信交流群
小伙伴老是出错,我再也不贴程序了

使用道具

报纸
qinly10 发表于 2015-9-23 21:21:52 |只看作者 |坛友微信交流群
  1. data a;
  2. do i = 1 to 60;
  3. output;
  4. end;
  5. run;
  6. data b;
  7. set a;
  8. retain sum1 sum2;
  9. sum1+i;
  10. if _n_=10 then sum2=0;
  11. if _n_>10 then set a(rename=(i = i_));
  12. sum2+i_;
  13. mean10 = (sum1-sum2)/10;
  14. run;
复制代码
这个是以10个Obs为框的

使用道具

地板
FlyUFalcon 在职认证  发表于 2015-9-24 18:16:24 |只看作者 |坛友微信交流群
这里的难点在于由于是交易日,所以日期上有断点,因此不能建立fixed window

可以 用sub-query方法。 楼上的回答 应该没有问题。 我之前问过和你相似的问题。

你可以看这里:
https://bbs.pinggu.org/thread-3906029-1-1.html
https://bbs.pinggu.org/thread-3775418-1-1.html

使用道具

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

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

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

GMT+8, 2024-4-25 16:29