楼主: cclvqiao
2302 5

[问答] SAS 删除某观测后面的记录 [推广有奖]

  • 0关注
  • 0粉丝

小学生

50%

还不是VIP/贵宾

-

威望
0
论坛币
10 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
58 点
帖子
8
精华
0
在线时间
3 小时
注册时间
2016-2-26
最后登录
2017-2-21

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
各位大神,SAS菜鸟现遇如下的问题,虚心求教,还望各位不吝赐教!多谢!
数据形式如下:
id flw_status
1      1
1      1
1      3
1      1
1      1
2      1
2      1
2      4
2      1
3      1
3      1

想要实现删除同一id号中flw_status 是3和4 后面的观测记录 ,如何编写代码?





二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:status 数据形式 虚心求教 记录 如何

沙发
wwang111 发表于 2016-8-12 16:19:02 |只看作者 |坛友微信交流群
Try this if dataset has been sorted by ID:

data wanted;
set test;
by id;
retain flag2;
if first.id then call missing(flag1,flag2);
flag1+1;
if flw_status in (3,4) then flag2=flag1;
if flag1>flag2>. then delete;
drop flag:;
run;

使用道具

藤椅
cclvqiao 发表于 2016-8-12 16:58:51 |只看作者 |坛友微信交流群
特别感谢您的方法和语句,已经实现了,再次感谢!
但是还有一个小问题,如果是
id flw_status flag2 flag1
1      1           .      1
1      1           .      2
1      3           3     3
1      1           3     4
1      4           5     5

这样情况下,最后一条及以下无法删除。不知道有没有方法,解决这个问题?

使用道具

板凳
wwang111 发表于 2016-8-12 17:40:19 |只看作者 |坛友微信交流群
try this:

data wanted;
set test;
by id;
if first.id then call missing(flag);
if flw_status in (3,4) then flag+1;
if (flag=1 and flw_status=1) or flag>1 then delete;
  drop flag;
run;

使用道具

报纸
cclvqiao 发表于 2016-8-12 18:02:20 |只看作者 |坛友微信交流群
wwang111 发表于 2016-8-12 17:40
try this:

data wanted;
十分感谢!

使用道具

地板
wwang111 发表于 2016-8-12 18:40:26 |只看作者 |坛友微信交流群
还有一种情况,就是flw_status的值除了1,3,4之外,还有其他值,那么可以用下面的程序,这个程序应该widely used:

data wanted;
set test;
  by id;
  if first.id then call missing(flag1,flag2);
   if flw_status in (3,4) then flag1+1;
   if flag1 ne . then flag2+1;
   if flag2>1 then delete;
    drop flag:;
run;

使用道具

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

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-27 12:59