微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

不使用 IML 重塑 SAS 表

如何解决不使用 IML 重塑 SAS 表

我想知道是否可以在不使用 SAS/IML 的情况下在 SAS 中重塑以下 have 表来生成 want 表。

有:

+--------+------+------+------+
|  NAME  | var1 | var2 | var3 |
+--------+------+------+------+
| Q1_ID1 |    1 |    2 |    3 |
| Q1_ID2 |    4 |    5 |    6 |
| Q2_ID1 |    7 |    8 |    9 |
| Q2_ID2 |   10 |   11 |   12 |
| Q3_ID1 |   13 |   14 |   15 |
| Q3_ID2 |   16 |   17 |   18 |
+--------+------+------+------+

想要:

+----------+----+----+----+
|   NAME   | Q1 | Q2 | Q3 |
+----------+----+----+----+
| var1_ID1 |  1 |  7 | 13 |
| var1_ID2 |  4 | 10 | 16 |
| var2_ID1 |  2 |  8 | 14 |
| var2_ID2 |  5 | 11 | 17 |
| var3_ID1 |  3 |  3 | 15 |
| var3_ID2 |  6 |  6 | 18 |
+----------+----+----+----+

重现have表的代码如下:

data have;
infile datalines delimiter=",";
input NAME :$8. var1 :8. var2 :8. var3 :8.;
datalines;
Q1_ID1,1,2,3
Q1_ID2,4,5,6
Q2_ID1,7,8,9
Q2_ID2,10,11,12
Q3_ID1,13,14,15
Q3_ID2,16,17,18
;
run;

解决方法

需要两个转置,中间有一些撕裂和组合。

data have;
infile datalines delimiter=",";
input NAME :$8. var1 :8. var2 :8. var3 :8.;
datalines;
Q1_ID1,1,2,3
Q1_ID2,4,5,6
Q2_ID1,7,8,9
Q2_ID2,10,11,12
Q3_ID1,13,14,15
Q3_ID2,16,17,18
;
run;

proc transpose data=have out=stage;
  by name;
  var var:;
run;

data stage2(keep=name col1 qtr);
  set stage;
  qtr = scan(name,'_');           * tear apart;
  id = scan(name,'_');
  name = catx('_',_name_,id);     * put together;
run;

proc sort data=stage2;
  by name qtr;
run;

proc transpose data=stage2 out=want;
  by name;
  id qtr;
run;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。