全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
1910 4
2014-08-23
复制代码
提示说 if 那里出问题了,,有人知道如果不用if的话,改换成什么吗??when试过了也不可以
二维码

扫码加我 拉你入群

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

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

全部回复
2014-8-24 03:53:44
Syntax is wrong. If is not part of SQL.

Please tell us what you really want?
二维码

扫码加我 拉你入群

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

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

2014-8-24 09:29:59
bobguy 发表于 2014-8-24 03:53
Syntax is wrong. If is not part of SQL.

Please tell us what you really want?
我现在有6月份公司规模百分位数,有20%、40%、60%、80%的,想把其他月份公司的size按照这个百分位数划分相应的区间,,,这部分程序是组fama french 25 portfolios的一部分
二维码

扫码加我 拉你入群

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

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

2014-8-25 01:49:50
Ryomac 发表于 2014-8-24 09:29
我现在有6月份公司规模百分位数,有20%、40%、60%、80%的,想把其他月份公司的size按照这个百分位数划分相 ...
You even don't need a left join if I understand the problem correct.

Here is a simple example with the logic.

data sales;
   do month=1 to 6;
      n=ranuni(123)*1000;
          do id=1 to n;
             sales=round(ranuni(123)*10000 ,1);
                 output;
          end;
        end;
run;

proc means data=sales noprint;
var sales;
output out=pctls p20=p20 p40=p40 p60=p60 p80=p80 ;
where month=6 ;
run;

proc sql;
   create table size_assign      
   as select month, sales,
        case when sales<=p20 then 's1'
             when p20<sales<=p40 then 's2'
         when p40<sales<=p60 then 's3'
                 when p60<sales<=p80 then 's4'
                 else 's5'
                end as size_port
   from  sales , pctls
   ;
   quit;

   proc print;run;
二维码

扫码加我 拉你入群

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

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

2014-8-25 12:06:44
可能是我没说清楚,你的解决方案和我要的有点出入,,不过问题还是解决了,谢谢了
二维码

扫码加我 拉你入群

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

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

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

说点什么

分享

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