楼主: dxystata
4618 1

proc transpose的列名问题 [推广有奖]

版主

大师

34%

还不是VIP/贵宾

-

TA的文库  其他...

Software

中英文Ebook

R学习

威望
2
论坛币
182304 个
通用积分
15205.6031
学术水平
208 点
热心指数
271 点
信用等级
174 点
经验
291157 点
帖子
5375
精华
1
在线时间
13478 小时
注册时间
2006-6-21
最后登录
2024-4-26

初级学术勋章 初级热心勋章 中级热心勋章 初级信用勋章

20论坛币
  1. data aaa;
  2. input usubjid x1 x2$ x3$;
  3. cards;
  4. 1 1 1 a
  5. 1 2 2 b
  6. 2 1 1 a
  7. 3 1 2 b
  8. 4 2 2 b
  9. ;
  10. run;

  11. proc sql noprint;
  12.         create table bbb as
  13.         select x1,x3,count(distinct usubjid) as sum
  14.         from aaa
  15.         group by x1,x3;
  16. quit;

  17. proc transpose data=bbb prefix=col out=ccc(drop=_:);
  18.         var sum;
  19.         id x1 x3;
  20.         by x1 x3;
  21. run;
复制代码
数据集ccc中col1a col1b col2b,不改变数据集aaa和bbb情况下,采用proc transpose使其列名为col11 col12 col22。谢谢!

关键词:Transpose Trans pose ans POS
沙发
吕小布韦 发表于 2016-10-31 10:41:05 |只看作者 |坛友微信交流群
想了一个办法,先产生一个format,指定a=1,b=2,不知道是否符合你意。
  1. proc format ;
  2. value $trans 'a'='1'
  3.       'b'='2';
  4.           run;

  5. proc transpose data=bbb prefix=col out=ccc(drop=_:);
  6.         var sum;
  7.         id x1 x3;
  8.         by x1 x3;
  9.                 format x3 $trans.;
  10. run;

  11. data ccc;
  12. set ccc;
  13. format x3;
  14. run;
复制代码
结果:
Obs    x1    x3    col11    col12    col22

1      1    a       2        .        .
2      1    b       .        1        .
3      2    b       .        .        2
已有 1 人评分论坛币 学术水平 热心指数 信用等级 收起 理由
admin_kefu + 30 + 2 + 2 + 2 热心帮助其他会员

总评分: 论坛币 + 30  学术水平 + 2  热心指数 + 2  信用等级 + 2   查看全部评分

使用道具

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

本版微信群
加好友,备注cda
拉您进交流群

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

GMT+8, 2024-4-27 04:57