SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 608|回复: 1
打印 上一主题 下一主题

问个merge的问题

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2011-3-28 10:06:13 | 只看该作者

问个merge的问题

data a b c;
merge ca cb;
by cd md sd td;
if ac = . then
do;
   ac = 0;
   output c;
   output a;
   end;
else if ay = . then
do;
   ay = 0;
   output b;
   output a;
end;
else output a;
run;

请问程序是先执行完merge之后再通过if-else的判断进行不同的输出么?
如果不是,那if-else语句是怎样执行的,谢谢。
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2011-3-29 03:21:58 | 只看该作者

Re: 问个merge的问题

说的不错。也可以理解成merge出每一条记录,然后根据条件输出。
不过或许你要考虑避免使用这种条件性的输出, 原因是:
1.这些条件有时候不是很直观。也就是ac或者ay是否missing,一个是其自身的缺失,一个是由于merge而导致的缺失。而后者往往并不是显而易见的。
2.某些值在不同的输出集里往往不一致。比如说第二个ay在c和b里的表现或许不同。这个值虽然现在对你来讲或许无关紧要,但是在以后的程序中却有可能造成混淆。
京剧
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2025-6-11 09:05 , Processed in 0.067749 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表