SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 1111|回复: 3
打印 上一主题 下一主题

如何保留每个id前两行observation?

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2007-1-26 17:53:30 | 只看该作者

如何保留每个id前两行observation?

比如:有数据集a:
id price amount
1    5     3
1    6     4
1    7     8
1   10     11
2    3     5
2    4     7
2    5     6
2    7     3
如何得到
id price amount
1   5     3
1   6     4
2   3     5
2   4     7
就是说,要保留每个id前两行的observation该怎么做?谢谢!!!!
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2007-1-26 22:16:16 | 只看该作者

RE:

/* Assume the dataset being sorted by id. */
[code:24794]data a(drop=flag); set a; by id;
if first.id then flag=0;
flag+1;
if flag <=2 then output;
run;
[/code:24794]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2007-1-26 22:23:36 | 只看该作者

数据集c就是结果

数据集c就是要的结果。[code:fb1ef]data a;
input id price amount;
cards;
1 5 3
1 6 4
1 7 8
1 10 11
2 3 5
2 4 7
2 5 6
2 7 3
;
data b;
set a;
by id;
if first.id then i=1;
else i+1;
data c(drop=i);
set b;
if i<=2;
run;[/code:fb1ef]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2007-1-27 01:24:55 | 只看该作者

谢谢

谢谢两位!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2025-6-11 10:53 , Processed in 0.081948 second(s), 19 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表