SAS-数据集添加序号

文章介绍了在SAS数据集中添加序号的两种方法:一是使用_data_内置变量和赋值操作,二是通过PROCSQL的monotonic()函数。对于同一ID下的多条观测,文章详细讲解了先排序然后利用first.逻辑和保留变量(RETAIN)进行序列编号的步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SAS数据集添加序号

一、数据集添加序号

在这里插入图片描述

示例

/** 方法1 **/
data class1; 
  set sashelp.class; 
  seq = _N_; /** 添加序号 **/
run;  

/** 方法2 **/
proc sql;
  create table class2 as 
  select monotonic() as id, *  /** monotonic()添加id **/
  from sashelp.class ;
quit;

二、同一ID多条观测加序号

在这里插入图片描述
第一步:排序 proc sort
第二步:first语句、累加

data t1;
input id name$ sex$ age subject$ score;
cards;
1001 Tom F 25 Chinese 80
1001 Tom F 25 Math 72
1001 Tom F 25 English 90
1003 Lisa M 20 Chinese 65
1003 Lisa M 20 Math 93
1005 Anna M 26 Chinese 93
1005 Anna M 26 Math 70
1002 Lyli M 21 Chinese 85
;
run;
proc print data=t1;run;

proc sort data=t1; by id subject; run;

data t2;
 set t1;
  by id subject ;   /* 与排序的变量一致 */
  retain SEQ;
  if first.id then SEQ = 1 ;   
  else SEQ = SEQ +1 ;
run;
proc print data=t2;run;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值