楼主: rockfido
3452 14

[原创博文] 请教一个SAS数据处理的问题 [推广有奖]

11
wdang21 在职认证  发表于 2010-7-19 11:30:11
data wkn;                                                                                                                              
input name $ type $;                                                                                                                    
cards;                                                                                                                                 
A    1                                                                                                                                 
A    1                                                                                                                                 
A    2                                                                                                                                 
B    1                                                                                                                                 
C    1                                                                                                                                 
C    3                                                                                                                                 
C    2                                                                                                                                 
;                                                                                                                                       
run;                                                                                                                                    
data wkn1;                                                                                                                              
set wkn nobs=n;                                                                                                                        
by name;                                                                                                                                
retain typeall;                                                                                                                        
if first.name then do;                                                                                                                  
k=1;                                                                                                                                    
do i=1 to n;                                                                                                                           
set wkn(rename=(name=na type=ty)) point=i;                                                                                             
if (name=na) and (k=1) then do;                                                                                                         
typeall=ty;                                                                                                                             
k=k+1;end;                                                                                                                              
else if(name=na) and (k>1) then do;                                                                                                     
typeall=compress(typeall||ty);end;                                                                                                      
end;end;                                                                                                                                
proc print;                                                                                                                             
var name type typeall;                                                                                                                  
run ;

输出……
已有 1 人评分热心指数 收起 理由
pobel + 1 精彩帖子

总评分: 热心指数 + 1   查看全部评分

12
rockfido 在职认证  发表于 2010-7-20 13:37:46
thank you guys all.

i almost forgot check this post.

here are some other solutions i got:

data b;
set b;
TYPECOMBINE=cat(col1,col2,col3); /*this is the point you need to check*/
TYPEALL=compress(TYPECOMBINE,'.');
run;

--------------------------------

data temp(keep=name typeall);
length typeall $200;
retain typeall;
set a;
by name;
if first.name then typeall=type;
else typeall=cats(typeall,type);
if last.name then output;
run;

13
anniegirl 发表于 2010-7-20 14:52:13
高手们,学习啦!

14
hopewell 发表于 2010-7-23 16:05:07
  1. data raw;
  2.         input NAME $ TYPE;
  3. datalines;
  4. A    1
  5. A    1
  6. A    2
  7. B    1
  8. C    1
  9. C    3
  10. C    2
  11. ;

  12. data out;
  13.         length typeall $10;
  14.         do _n_=1 by 1 until(last.name);
  15.                 set raw;
  16.                 by name;
  17.                 typeall=cats(typeall,put(type,best.));
  18.         end;
  19.         do _n_=1 to _n_;
  20.                 set raw;
  21.                 output;
  22.         end;
  23. run;
复制代码
已有 1 人评分学术水平 热心指数 收起 理由
jingju11 + 1 + 1

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

15
zhentao 发表于 2010-7-27 13:29:22
学习了。mark。

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

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