首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SAS转置从宽到长,有重复项

SAS转置从宽到长,有重复项
EN

Stack Overflow用户
提问于 2019-04-04 23:48:24
回答 2查看 88关注 0票数 1

我将转置下表:

X财年第一财年第一财年第二财年第三财年

一个月1个月,一个月2个月,3个月。

一个月2个月,一个月3个月,4个月。

*9

转到

X、X、Y

第一个月是第一天。

一份报告2份报告。

一份报告:第三份

一份报告2份报告。

一年三个月。

A:第4页:

B:7%。

B:8个月。

B:第9页

我试过这段代码。

代码语言:javascript
复制
PROC TRANSPOSE DATA=table1 OUT=table2;
BY X;
RUN;

但是,它给出了以下输出

X-COL1-COL2-COL2

一个月1个月,一个月2个月。

*3

*4

B:7%。

B:8个月。

B:第9页

有谁知道怎么弄到我需要的桌子吗?

感谢您的任何想法,谢谢!

EN

回答 2

Stack Overflow用户

发布于 2019-04-05 02:37:35

像下面这样的东西应该可以工作

代码语言:javascript
复制
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;
票数 1
EN

Stack Overflow用户

发布于 2019-04-05 00:08:51

您可以使用以下代码,它添加一行,然后基于行转置。因为行号将是唯一的

代码语言:javascript
复制
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;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55520150

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档