楼主: judas21
6138 2

求问一个分组排序的sas程序,大谢! [推广有奖]

  • 0关注
  • 0粉丝

已卖:13份资源

本科生

51%

还不是VIP/贵宾

-

威望
0
论坛币
37 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
3414 点
帖子
85
精华
0
在线时间
62 小时
注册时间
2010-1-29
最后登录
2018-6-26

楼主
judas21 发表于 2011-7-19 20:11:23 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
弱问各位大虾,求问一个程序:比如现在有100支股票10年的月回报数据,在每一个月,按照股票月回报的高低分成10组,称之为组1、组2、组3…以此类推,每组10支股票。现在需要的是这样十个面板数据,就是所有组1、组2…组10的组合在这10年中的回报数据,换句话说,组1中就是10年中回报率最高的10%的股票,组10是10年中回报率最低的10%的股票。
求问这样的要求如何在sas中得以实现?请指教~
小弟拜谢!
二维码

扫码加我 拉你入群

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

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

关键词:sas程序 面板数据 回报率 请指教 程序 SAS 分组

沙发
yugao1986 发表于 2011-7-20 15:35:01
  1. /*这里以sashelp中是数据stocks为例*/
  2. data stocks;
  3. set sashelp.stocks(obs=100);
  4. keep stock open;
  5. run;
  6. /*你的需求是按回报率排序,这里是数据的开盘价降序排列*/
  7. /*替换一下应该可以*/
  8. proc sort data=stocks out=stocks1;
  9. by descending open;
  10. run;
  11. /*按10个数据一组分组*/
  12. data need;
  13.    set stocks1;
  14.    retain group;
  15.    select;
  16.    when(_n_<=10) do;group=1;end;
  17.     when(_n_<=20) do;group=2;end;
  18.   when(_n_<=30) do;group=3;end;
  19.    when(_n_<=40) do;group=4;end;
  20.     when(_n_<=50) do;group=5;end;
  21.      when(_n_<=60) do;group=6;end;
  22.    when(_n_<=70) do;group=7;end;
  23.     when(_n_<=80) do;group=8;end;
  24.      when(_n_<=90) do;group=9;end;
  25.    otherwise group=10;end;
  26. run;
复制代码
1# judas21
三人行必有我师

藤椅
judas21 发表于 2011-7-22 10:14:59
多谢多谢~ 2# yugao1986

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

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