Using first.variable and last.variables with accumulator variables

拈花ヽ惹草 提交于 2020-01-26 04:08:25

问题


I am trying to understand what this program does.

data a;
set b (keep=c d);
by c;
if first.c then e=0;
e+d;
if last.c;
run;

What confuses me is the following.

1), When there is not THEN statements, what does and IF statement do?

2), When there is no value evalueated, what does an IF statement do ? (why would it not say something like if first.c =1 ?)

3), My understanding is that e is an accumulator variable starting from 0, and d is added by iteration. But for some reason e represents the total for all values of c, not d even though we are adding d.

I am thinking that the first two questions will answer my question 3, but I would really appreciate your help.


回答1:


In SAS there are two different if statements - if-then-else and subsetting if. They have similar syntax but they do different things. You have one of each in your code.

This is how it's explained in the documentation:

The subsetting IF statement is equivalent to this IF-THEN statement:

if not (expression) then delete;




回答2:


Without a THEN clause the IF statement is a subsetting statement. Basically if the condition is not true the current iteration of the data step stops and control returns to the top to process the next observation.

SAS evaluates any value that is not zero or missing as true. The automatic FIRST. and LAST. variables generated when you use a BY statement will have values of either 1 (true) or 0 (false). The FIRST. variable will be true when on the first observation for the BY group and the LAST. variable will be true when on the last observation for the BY group.

Your data step is getting the sum of the values of D for each value of C.



来源:https://stackoverflow.com/questions/53276299/using-first-variable-and-last-variables-with-accumulator-variables

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!