将序列号添加到SAS

时间:2012-08-31 12:51:48

标签: sas

我正在将一个表从Access数据库导入SAS,其中序列列已损坏。我需要在SAS中创建一个新的序列列。我不想在Access中重新创建序列号,因为源表会定期补充。是否有可以添加到SAS的自动编号列?

3 个答案:

答案 0 :(得分:5)

您可以这样做:

data want;
set have;
autonumber+1;
run;

还有_N_,它是通过数据步骤循环的迭代次数,在正常数据步骤中等于行号。它不会写入数据集,但始终可以作为普通变量进行访问。

答案 1 :(得分:4)

当您在SAS中读取数据集时,_n_指的是观察编号。这应该适合你:

data new;
 set old;
 seqno = _n_;
run;

答案 2 :(得分:3)

_N_与观察数不相同的典型示例 - 用于将变量之和附加到类变量的每个值的每一行的DoW循环。最后请注意_N_不返回行号,而是返回迭代次数 - 在这种情况下,数据步循环对x的每个值迭代一次,而不是每行一次,如行通过do..until循环拉入。

data have;
do x = 1 to 5;
  do y = 1 to 3; 
    z=floor(7*ranuni(7));
    rownum+1;
    output;
  end;
end;
run;

data test;
 do t=1 by 1 until (last.x);
    set have;
    by x;
    sum_z+z;
 end;
 do t=1 by 1 until (last.x);
    set have;
    by x;
    output;
    put x= z= sum_z= _N_= rownum=;
 end;
 sum_z=0;
run;

日志:

x=1 z=2 sum_z=12 _N_=1 rownum=1
x=1 z=5 sum_z=12 _N_=1 rownum=2
x=1 z=5 sum_z=12 _N_=1 rownum=3
x=2 z=5 sum_z=13 _N_=2 rownum=4
x=2 z=3 sum_z=13 _N_=2 rownum=5
x=2 z=5 sum_z=13 _N_=2 rownum=6
x=3 z=5 sum_z=12 _N_=3 rownum=7
x=3 z=5 sum_z=12 _N_=3 rownum=8
x=3 z=2 sum_z=12 _N_=3 rownum=9
x=4 z=3 sum_z=12 _N_=4 rownum=10
x=4 z=5 sum_z=12 _N_=4 rownum=11
x=4 z=4 sum_z=12 _N_=4 rownum=12
x=5 z=6 sum_z=13 _N_=5 rownum=13
x=5 z=3 sum_z=13 _N_=5 rownum=14
x=5 z=4 sum_z=13 _N_=5 rownum=15