楼主: litui
8121 1

[原创博文] proc transpose 块转置 [推广有奖]

  • 0关注
  • 0粉丝

学前班

70%

还不是VIP/贵宾

-

威望
0
论坛币
0 个
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
123 点
帖子
2
精华
0
在线时间
2 小时
注册时间
2010-12-23
最后登录
2013-8-13

litui 发表于 2010-12-23 21:53:54 |显示全部楼层
本帖最后由 wanghaidong918 于 2013-1-14 01:21 编辑

如何将
nuq questions value item
1 r11
1 r2 5
1 r32 2
1 r33 2
1 r4 21
1 r4 3 2
1 r4 3 1
转化为,
nuq r1 r2 r3-1 r3-2 r4-1 r4-2
1 1 5 2 2 2 1
1 3 2 3 2
1 3 1


sas 的 proc transpose 是对列的的转置,现在想对var questions 里的 r3 r4进行块转置,例如,
r4 对应的 value值变为,r41 ,
r4对应的item值变为 r42
r1 ,r2 只有一个值,没有问题,r3 r4有多个值,
不知道该怎么弄了。
试验了好久没成功,加了LET 也只能出现一个数据,但是要全部的,


有没有做过类似例子的,帮忙看看,或者给个指导方向,谢谢
关键词:Transpose Trans pose ans POS

stata SPSS
yitianqian 发表于 2013-4-30 15:41:45 |显示全部楼层
data quest;
input nuq questions $ value item;
datalines;
run;
proc sort data=quest;
by nuq questions;
run;
data quest_i;
set quest;
by nuq questions;
if first.questions=1 then index=0;
index+1;
run;
proc transpose data=quest_i out=quest_t(rename=(col1=vi));
by nuq questions index;
run;
data quest_t;
set quest_t;
name='_'||_name_;
drop _name_;
run;
proc sort data=quest_t;
by nuq index;
run;
proc transpose data=quest_t out=quest_t1;
by nuq index;
id questions name;
run;
stay hungry,stay foolish
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 我要注册

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2019-3-22 19:43