SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

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

再来一个HOMEWORK:表格相减

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2004-6-9 04:57:46 | 只看该作者

再来一个HOMEWORK:表格相减

有2个表格A,B,要求从A中删除B中有的记录,且维持原表顺序,例如表A
data a;
        input id value;
        cards;
        1 1
        2 3
        3 1
        4 4
        5 5
        6 2
        7 1
        8 4
        9 3
        10 1
;
run;
表B
data b;
        input value;
        cards;
        2
        4
;
run;
结果应该是
id  value
1 1
2 3
3 1
5 5
7 1
9 3
10 1
我作了一个,可总觉得效率不高,表的遍历过多,表格大的话就很慢了
data temp;
        set a b(in=bb);
        if (bb=1) then id=0;
run;

proc sort data=temp;
        by value id;
run;

data res (drop=cur);
        set temp;
        retain cur -1;
        if id=0 then
        cur=value;
        else do;
                if (value ne cur) then output;
        end;
run;

proc sort data=res;
        by id;
run;
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2004-6-9 08:56:17 | 只看该作者

ANSWER

试试这个:
[code:f87c9]PROC SQL;
        SELECT * FROM A
                WHERE VALUE NOT IN (SELECT VALUE FROM B);
QUIT;[/code:f87c9]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2004-6-9 09:00:48 | 只看该作者

ANSWER2

再试试这个:
[code:b4360]PROC SQL NOPRINT;
        SELECT DISTINCT VALUE INTO :STRVALUE SEPARATED BY ',' FROM B;
QUIT;
DATA RESULT;
        SET A;
        WHERE VALUE NOT IN (&STRVALUE);
RUN;[/code:b4360]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2004-6-9 10:11:00 | 只看该作者

Try this!

[code:3436b]proc sort data=a;
    by value;
run;

data tmp;
    merge a b(in=d);
    by value;
    if not d;
run;

proc sort data=tmp;
    by id;
run;[/code:3436b]
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-10 07:59 , Processed in 0.104146 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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