SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

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

请帮忙看以下这个macro,错在哪里?

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2012-11-24 03:55:32 | 只看该作者

请帮忙看以下这个macro,错在哪里?

%macro d_check(din=,fn=);
proc sql;
create table a as
  select * from &din. having %sysfunc(upcase(name))="%sysfunc(upcase(&fn.))";
quit;
%mend;

%d_check(din=sashelp.class,fn=jane)

在sashelp.class中,是存在这个'Jane'名字的,e.g. proc sql; create table a as select * from sashelp.class having upcase(name)='JANE'; quit;
但不知道为何这个macro程序就无法实现?
请问,错在哪里,请帮忙指点一下。
谢谢!
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2012-11-24 09:38:03 | 只看该作者

Re: 请帮忙看以下这个macro,错在哪里?

变量name不是宏变量,故不用宏函数%upcase,而%upcase是可以直接使用的宏函数,Proc sql中转换大小写有专用函数upper和lower
%macro d_check(din=,fn=);
        proc sql;
                create table a as
                select * from &din
                having upper(name)="%upcase(&fn)";
quit;
%mend;
%d_check(din=sashelp.class,fn=jane)
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2012-11-28 07:31:30 | 只看该作者

Re: 请帮忙看以下这个macro,错在哪里?

thx.
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-8 22:01 , Processed in 0.101738 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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