我将转置下表:
X财年第一财年第一财年第二财年第三财年
一个月1个月,一个月2个月,3个月。
一个月2个月,一个月3个月,4个月。
*9
转到
X、X、Y
第一个月是第一天。
一份报告2份报告。
一份报告:第三份
一份报告2份报告。
一年三个月。
A:第4页:
B:7%。
B:8个月。
B:第9页
我试过这段代码。
PROC TRANSPOSE DATA=table1 OUT=table2;
BY X;
RUN;但是,它给出了以下输出
X-COL1-COL2-COL2
一个月1个月,一个月2个月。
*3
*4
B:7%。
B:8个月。
B:第9页
有谁知道怎么弄到我需要的桌子吗?
感谢您的任何想法,谢谢!
发布于 2019-04-05 02:37:35
像下面这样的东西应该可以工作
data want;
set have;
array name(*) Y1--Y3;
do i = 1 to dim(name);
Y=name[i];
output;
end;
Drop y1 y2 y3 i;
run;发布于 2019-04-05 00:08:51
您可以使用以下代码,它添加一行,然后基于行转置。因为行号将是唯一的
data have;
input X $ Y1 Y2 Y3;
datalines;
a 1 2 3
a 2 3 4
b 7 8 9
;
run;
data have;
set have;
row=_n_;
run;
PROC TRANSPOSE DATA=have OUT=want(rename=(COL1=Y) drop=_NAME_ row);
by row x;
RUN;
proc print data=want; run;https://stackoverflow.com/questions/55520150
复制相似问题