Как мы можем сделать условную итерацию в наборе данных sas - PullRequest
0 голосов
/ 18 февраля 2009

Как мы можем выполнить итерацию в наборе данных sas. Например я выбрал первое. переменной. И хотите найти возникновение определенного условия и установить значение, когда оно удовлетворяет

1 Ответ

3 голосов
/ 21 февраля 2009

Шаг данных SAS имеет встроенный цикл наблюдения. Вам не нужно ничего делать, если вы не хотите, по какой-то причине. Например, следующее генерирует случайное число для каждого наблюдения:

data one;
  set sashelp.class;
  rannum = ranuni(0);
run;

Если вы хотите перебрать переменные, то есть массивы. Например, следующий код инициализирует переменные от var1 до var10 случайными числами:

data one;
  array vars[1:10] var1-var10;
  do i = 1 to 10;
    vars[i] = ranuni(0);
  end;
run;

Первый. и последнее. флаги генерируются автоматически, когда вы устанавливаете (отсортированные) данные с помощью оператора by. Пример:

proc sort data=sashelp.class out=class;
  by age;
run;
data one;
  set class;
  by age;
  first = first.age;
  last = last.age;
run;
/* check */
proc print data=one;
run;
/* on lst
  Obs    Name       Age    first    last

  1    Joyce       11      1        0
  2    Thomas      11      0        1
  3    James       12      1        0
  4    Jane        12      0        0
  5    John        12      0        0
  6    Louise      12      0        0
  7    Robert      12      0        1
  8    Alice       13      1        0
  ...
 18    William     15      0        1
 19    Philip      16      1        1
*/
...