全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
2053 4
2012-08-31
表1 数据格式如下:
a 2002  1  
a 2003  2  
a 2004  3  
b 2002  9   
b 2003  8
b 2004  7
c 2002  3
c 2003  5
c 2004  9

请问如何转化为下面的表2 结构?
date    a b  c
2002   1 9 3
2003   2 8 5
2004   3 7 9

还想问问, 如何把表2结构转化为表1结构?
二维码

扫码加我 拉你入群

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

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

全部回复
2012-8-31 00:58:42
ding
二维码

扫码加我 拉你入群

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

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

2012-8-31 08:40:18
U can use "Transpose" procedure to handle it.

data t1;
        input tit$ yr $ val;
cards;
a 2002  1
a 2003  2
a 2004  3
b 2002  9
b 2003  8
b 2004  7
c 2002  3
c 2003  5
c 2004  9
;run;
proc sort data = t1;
        by yr tit;
run;
proc transpose data = t1 out = t2(drop = _NAME_);
        id tit;
        by yr;
        var val;
run;
二维码

扫码加我 拉你入群

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

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

2012-8-31 09:41:10
如果不想transpose 后, tit 成为header , 那该怎么做呢?
二维码

扫码加我 拉你入群

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

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

2012-8-31 17:05:14
lachance 发表于 2012-8-31 09:41
如果不想transpose 后, tit 成为header , 那该怎么做呢?
Sometimes, the "tit" is not in English character, so we have to create a new variable to replace it.
Here is my way.

data t1;
        input tit$ yr $ val;
cards;
a 2002  1
a 2003  2
a 2004  3
b 2002  9
b 2003  8
b 2004  7
c 2002  3
c 2003  5
c 2004  9
;run;
proc sort data = t1;
        by tit;
run;
data t2 temp(keep = tit fid);
        set t1;
        by tit;
        if first.tit then fid + 1;
run;
proc sort data = temp nodupkey; by _all_; run;
proc sort data = t2;
        by yr fid;
run;
proc transpose data = t2 out = t3(drop = _NAME_);
        id fid;
        by yr;
        var val;
run;
proc sql noprint;
        select compress("_"||put(fid,8.)||'="'||tit||'"') into:vars_label separated by ' '
                from temp;
quit;
data t4;
        set t3;
        label &vars_label.;
run;
二维码

扫码加我 拉你入群

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

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

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群