楼主: dxystata
2823 3

根据已有数据集更新另一个数据集 [推广有奖]

版主

大师

34%

还不是VIP/贵宾

-

TA的文库  其他...

Software

中英文Ebook

R学习

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

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

50论坛币
  1. data aaa;
  2. input id line x1$;
  3. cards;
  4. 1 1 b
  5. 1 2 a
  6. 1 3 c
  7. 1 4 d
  8. 2 5 b
  9. 2 6 a
  10. 2 7 c
  11. ;
  12. run;

  13. data bbb;
  14. input line x1$;
  15. cards;
  16. 1 b
  17. 2 a
  18. 3 c
  19. 4 d
  20. run;
复制代码
得到的数据集为
1 1 b
1 2 a
1 3 c
1 4 d
2 1 b
2 2 a
2 3 c

如何实现,x1 的取值比较多,希望程序能通用,谢谢!

最佳答案

wwang111 查看完整内容

proc sort data=aaa; by x1; run; proc sort data=bbb; by x1; run; data wanted; merge aaa bbb(rename=(line=line1)); by x1; line=line1; drop line1; run; proc sort data=wanted; by id line x1; run;
关键词:数据集 Input cards Data line 通用 程序 如何
沙发
wwang111 发表于 2016-8-28 19:57:21 |只看作者 |坛友微信交流群
proc sort data=aaa;
by x1;
run;

proc sort data=bbb;
by x1;
run;

data wanted;
merge aaa bbb(rename=(line=line1));
  by x1;
  line=line1;
  drop line1;
run;

proc sort data=wanted;
by id line x1;
run;

使用道具

藤椅
wwang111 发表于 2016-8-28 20:06:45 |只看作者 |坛友微信交流群
data fmt;
set bbb;
retain fmtname '$x1fmt';
type='c';
rename x1=start line=label;
run;

proc format cntlin=fmt;
run;

data wanted;
set aaa;
line=put(x1,$x1fmt.)+0;
run;

使用道具

板凳
dxystata 发表于 2016-8-28 21:10:31 |只看作者 |坛友微信交流群
wwang111 发表于 2016-8-28 20:06
data fmt;
set bbb;
retain fmtname '$x1fmt';
不希望用format

使用道具

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

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

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

GMT+8, 2024-4-25 18:24