0

我想知道是否可以have在不使用 SAS/IML 生成表格的 SAS中重塑下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;
4

1 回答 1

3

需要两个转置,其中一些分开并放在一起。

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,1,'_');           * tear apart;
  id = scan(name,2,'_');
  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;
于 2020-12-22T10:51:40.770 回答