楼主: dxystata
3096 3

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

版主

已卖:302份资源

大师

37%

还不是VIP/贵宾

-

TA的文库  其他...

Software

中英文Ebook

R学习

威望
2
论坛币
183395 个
通用积分
15333.1475
学术水平
208 点
热心指数
271 点
信用等级
174 点
经验
298627 点
帖子
5586
精华
1
在线时间
13632 小时
注册时间
2006-6-21
最后登录
2025-12-22

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

楼主
dxystata 发表于 2016-8-28 19:57:20 |AI写论文
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
拉您进交流群
GMT+8, 2025-12-29 08:09