楼主: kikolk
1450 2

SAS数据集合并 [推广有奖]

  • 0关注
  • 0粉丝

小学生

42%

还不是VIP/贵宾

-

威望
0
论坛币
0 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
36 点
帖子
3
精华
0
在线时间
10 小时
注册时间
2013-4-10
最后登录
2024-3-26

楼主
kikolk 发表于 2016-9-23 03:14:07 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
现在我手中的两个数据集类似下面:
dataset1     x1      x2      x3                 dataset2      time     y2     y3
loan1                                                     loan1        1
loan2                                                     loan1        2
loan3                                                     loan2        1
                                                             loan2        2
                                                             loan2        3
                                                             loan3        1

如何才能merge成
                  X1     X2     X3       TIME      Y2          Y3
loan1                                          1
                                                  2
loan2                                          1
                                                  2
                                                  3
loan3                                          1

多谢大家帮忙指点
二维码

扫码加我 拉你入群

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

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

关键词:SAS数据集合并 sas数据集 数据集 dataset DataS 如何

沙发
wang1839 在职认证  发表于 2016-9-23 10:22:59
  1. data a;
  2. infile datalines missover;
  3. input dataset1 $ x1-x3;
  4. cards;
  5. loan1
  6. loan2
  7. loan3
  8. ;
  9. run;                                                     

  10. data b;
  11. infile datalines missover;
  12. input dataset2 $     time     y2     y3;
  13. cards;
  14. loan1        1
  15. loan1        1
  16. loan2        1
  17. loan2        2
  18. loan2        3
  19. loan3        1
  20. ;
  21. run;

  22. /*sql approach*/
  23. proc sql;
  24. create table c as select a.*,b.* from a,b where a.dataset1=b.dataset2 order by dataset1;
  25. quit;

  26. /* eaqual data approach*/
  27. data c;
  28.         set a;
  29.         do i=1 to all;
  30.         set b point=i nobs=all;
  31.         if dataset1=dataset2 then output;
  32.         end;
  33. run;


  34. data final;
  35.         set c(drop=dataset2);
  36.         by dataset1;
  37.         if not first.dataset1 then dataset1=.;
  38. run;
复制代码
A man who is frustrated will never stand up.

藤椅
流水不朽 发表于 2016-9-24 17:10:42
proc sort data=dt1(rename=(dataset1=dataset));by dataset;run;
proc sort data=dt2(rename=(dataset2=dataset));by dataset;run;
data   tmp;
  merge dt1(in=a)
            dt2(in=b);
       by dataset;
       if   b;
   retain dataset_;
       if   first.dataset then
            dataset_=dataset;
      else dataset_="";
run;

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

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