全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
1737 7
2011-10-28
悬赏 5 个论坛币 已解决
求助:知道某变量的一个属性,想填补该变量空着的该属性。
举例如下:
原始表为:

assn                 cpc
清华大学         北京
清华大学
东北大学               
东北大学         辽宁
李三     
李三
王二
王二小            上海
王二小

想把相同assn的cpc全部填补上,其他的就空着,处理后格式为:
assn                 cpc
清华大学         北京
清华大学         北京
东北大学         辽宁      
东北大学         辽宁
李三     
李三
王二
王二小            上海
王二小            上海
————————————————————————————
注:之前求助,有位大侠帮忙写了个程序,但是运行后发现把所有assn的cpc都填补上了,就是把“李三”和“王二”也补上了;
程序如下:
proc sort data=dianzi.p1;by assn;run;
proc sort data=dianzi.p1;   
  by assn descending cpc;
run;
data dianzi.p2;
   do until(last.assn);
     set dianzi.p1;
     by assn;
      length cpc0 $ 50;
      retain cpc0 "";
      if cpc^=" " then cpc0=cpc;
      else cpc=cpc0;
          output;
        end;
          drop cpc0;
run;
__________________________

我的SAS刚开始学习,不知道如何对这个程序修改,哪位大侠帮帮忙,把程序完善一下吧
钱给的不多,辛苦各位了,多谢!!

最佳答案

stata18 查看完整内容

proc sort data=a;by assn descending cpc;run; data b;set a; by assn descending cpc; retain cpc1; if first.assn then cpc1=cpc; drop cpc; rename cpc1=cpc; run;
二维码

扫码加我 拉你入群

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

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

全部回复
2011-10-28 12:57:38
proc sort data=a;by assn descending cpc;run;
data b;set a;
by assn descending cpc;
retain cpc1;
if first.assn then cpc1=cpc;
drop cpc;
rename cpc1=cpc;
run;
二维码

扫码加我 拉你入群

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

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

2011-10-28 13:06:44
我只会E语言啊
二维码

扫码加我 拉你入群

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

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

2011-10-28 22:40:11
试试上面的程序。
二维码

扫码加我 拉你入群

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

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

2011-10-28 22:46:43
抱歉,别的帖子里已经解决了。
二维码

扫码加我 拉你入群

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

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

2011-10-29 11:31:44
This is a good to use a SAS formt. See example below,

data temp;
length assn   $8  cpc $6;
infile cards truncover;
input assn   cpc;
cards;
清华大学         北京
清华大学
东北大学               
东北大学         辽宁
李三     
李三
王二
王二小            上海
王二小
;

proc sort data=temp(where=(cpc ne ' ')) out=fmt nodupkey; by assn; run;

data fmt;
  set fmt;
  fmtname='$ASSN2ST';
  run;

proc format cntlin=fmt(rename=(assn=start cpc=label)); run;

data temp2;
  set temp;
  cpc2=put(assn,$ASSN2ST.);
run;

proc print;run;
二维码

扫码加我 拉你入群

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

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

点击查看更多内容…
相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

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