SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 655|回复: 5
打印 上一主题 下一主题

求助 b c d三个变量是否重复 给一个标识变量flag

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2009-4-16 14:46:48 | 只看该作者

求助 b c d三个变量是否重复 给一个标识变量flag

data have;
        input a b c d;
cards;
1 2 3 4
1 4 5 6
1 2 7 8
2 2 3 4
3 2 3 4
2 5 6 7
1 2 7 8
;
run;


如果按照b c d三个变量是否重复 给一个标识变量flag

a b c d flag
1 2 3 4  1
1 4 5 6  1
1 2 7 8  1
2 2 3 4  2
3 2 3 4  3
2 5 6 7  1
1 2 7 8  2

2 3 4重复了3次 分别用1 2 3表示 2 7 8重复了2次 分别用1 2表示 没有重复的均用1表示

sql能否实现吗?
回复 支持 反对

使用道具 举报

0

主题

0

帖子

2

积分

新手上路

Rank: 1

积分
2
沙发
发表于 2009-4-16 16:52:01 | 只看该作者

Re: 求助 b c d三个变量是否重复 给一个标识变量flag

用data比较好吧~~
觉着sql好像不会区别对待同样的observation~~
[code:tnevkbfh]
data have1;
set have;
no=_n_;
key=catx(',' ,of b--d);
run;

proc sort data=have1 ;
by key;
run;

data have1;
retain flag;
set have1;
by key;
if first.key=1 then flag=1;
else flag+1;
run;

proc sort data= have1 out=have(drop=no key);
by no;
run;
[/code:tnevkbfh]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2009-4-18 11:36:13 | 只看该作者

Re: 求助 b c d三个变量是否重复 给一个标识变量flag

data have;
input a b c d;
cards;
1 2 3 4
1 4 5 6
1 2 7 8
2 2 3 4
3 2 3 4
2 5 6 7
1 2 7 8
;
run;
data have_1;
set have;
n=_n_;
run;
proc sort; by a b c; run;
data have_2;
set have_1;
by a b c;
if first.a then flag=0;
flag+1;
run;
proc sort data=have_2; by n; run;*restore the previous order;

我没有软件。如果有问题可以自己调试一下。
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2009-4-20 12:30:13 | 只看该作者

Re: 求助 b c d三个变量是否重复 给一个标识变量flag

to deshengsu

得到的数据集flag有误!
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
5#
 楼主| 发表于 2009-4-20 20:55:23 | 只看该作者

Re: 求助 b c d三个变量是否重复 给一个标识变量flag

data have;
input a b c d;
cards;
1 2 3 4
1 4 5 6
1 2 7 8
2 2 3 4
3 2 3 4
2 5 6 7
1 2 7 8
;
run;
data have_1;
set have;
n=_n_;
run;
proc sort; by a b c; run;
data have_2;
set have_1;
by a b c;
if first.c then flag=0;*sorry, wrong syntax here;
flag+1;
run;
proc sort data=have_2; by n; run;*restore the previous order;
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
6#
 楼主| 发表于 2009-4-20 21:03:57 | 只看该作者

Re: 求助 b c d三个变量是否重复 给一个标识变量flag

data have;
input a b c d;
cards;
1 2 3 4
1 4 5 6
1 2 7 8
2 2 3 4
3 2 3 4
2 5 6 7
1 2 7 8
;
run;
data have_1;
set have;
n=_n_;
run;
proc sort; by b c d; run;
data have_2;
set have_1;
by b c d;
if first.d then flag=0;
flag+1;
run;
proc sort data=have_2 out=have_1(drop=n); by n; run;*restore the previous order;

*note: I did not read your question very well.Anyway, that should work.
Sorry again.
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-5 12:21 , Processed in 0.193348 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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