SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 678|回复: 2
打印 上一主题 下一主题

请问,在proc sql中,可以执行类似于do的循环码?

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2009-9-28 10:56:01 | 只看该作者

请问,在proc sql中,可以执行类似于do的循环码?

[color=#FF00BF:1voo374j][size=150:1voo374j]请问,在proc sql中,可以执行类似于在data步中的do...to...end的循环码?

多谢指教![/size:1voo374j][/color:1voo374j]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2009-9-28 12:40:00 | 只看该作者

Re: 请问,在proc sql中,可以执行类似于do的循环码?

用CASE WHEN...THEN ... END语句,case 语句可以嵌套。
例如:
[code:2ywa20ji]data a;
a=1;
b=0;
output;
a=2;
b=.;
output;
run;
proc sql;
        create table b as
        select a.a, a.b,
                (CASE when b=. then
                        case when a=1 then 'a miss'
                                 when a=2 then 'miss'
                                else ''
                        end
                        when b=1 then '1'
                        else ''
                END) as test
        from a;
quit;[/code:2ywa20ji]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2009-9-28 14:53:50 | 只看该作者

Re: 请问,在proc sql中,可以执行类似于do的循环码?

[color=#BF00BF:1ubey8rv][size=150:1ubey8rv]不好意思啊,我想实行的功能是类似于:[/size:1ubey8rv][/color:1ubey8rv]
[code:1ubey8rv]
%macro test;

data a;
set b;
%do i=1 %to 5;
select;
when var_&i. = '1'  xvar='x1';
when var_&i. = '2'  xvar='x2';
when var_&i. = '10'  xvar='B';
when var_&i. = '11'  xvar='Z';
otherwise xvar=.;
end;
%end;
run;

%mend test;

%test;
[/code:1ubey8rv]
[size=150:1ubey8rv][color=#BF00BF:1ubey8rv]
希望可以在proc sql中实现,谢谢!

[/color:1ubey8rv][/size:1ubey8rv]
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-6 02:40 , Processed in 0.067086 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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