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