SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 1957|回复: 7
打印 上一主题 下一主题

求教:如何进行宏变量计算

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2003-10-17 14:39:14 | 只看该作者

求教:如何进行宏变量计算

%let numRecordCount=11;
%let numBaseTableCount=19;
%let numPercentage=%eval((&numRecordCount/&numBaseTableCount)*100);
%put &numPercentage;
我觉得没有错啊,为什么结果是0?
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2003-10-17 16:10:52 | 只看该作者

Re: 求教:如何进行宏变量计算

[quote="shiyiming":787e0]%let numRecordCount=11;
%let numBaseTableCount=19;
%let numPercentage=%eval((&numRecordCount/&numBaseTableCount)*100);
%put &numPercentage;
我觉得没有错啊,为什么结果是0?[/quote:787e0]

上面的写法没有错,就应该等于0。
试试这个:
%let numPercentage=%[color=red:787e0]sysevalf[/color:787e0]((&numRecordCount/&numBaseTableCount)*100);
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2003-10-17 16:40:25 | 只看该作者
COOL,谢谢老大!
但是如果numRecordCount和numBaseTableCount都是由select count(*) into :numRecordCount from TableA和select count(*) into :numBaseTableCount from BaseTable得来的,结果似乎还是不对。有何良策?
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2003-10-18 00:10:41 | 只看该作者
是这个意思吗?好象没错呀!


data a;
do x=1 to 12;
output;
end;
run;
data b;
do y=1 to 48;
output;
end;
run;
proc sql;
select count(*) into :aa from a;
select count(*) into :bb from b;
quit;
%let cc=%sysevalf((&aa/&bb)*100);
%put &cc;
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
5#
 楼主| 发表于 2003-10-18 09:16:59 | 只看该作者
没错,就是这个意思,你的能跑正确。但在我实际程序中的确不成功。
不过没关系,实在不行,我用data step来计算,再用call symput赋值。
谢谢!
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
6#
 楼主| 发表于 2003-10-20 09:08:42 | 只看该作者

to Jerry兄

这段代码测试过吗??
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
7#
 楼主| 发表于 2003-10-20 11:41:42 | 只看该作者
[quote="shiyiming":c7695]COOL,谢谢老大!
但是如果numRecordCount和numBaseTableCount都是由select count(*) into :numRecordCount from TableA和select count(*) into :numBaseTableCount from BaseTable得来的,结果似乎还是不对。有何良策?[/quote:c7695]

log中是否显示:
WARNING: Apparent symbolic reference NUMRECORDCOUNT not resolved.
....等等?

如果这样的话,问题可能是:
proc sql select into:产生的宏变量是局部的/local。如果产生和调用这两个宏变量不在一个宏内,就会出现问题,因为在第一个宏结束时,local macro variables自动从symbol table中去除。

方法2个:
1/ 在第一个宏中加上
%global numRecordCount numBaseTableCount; 在第二个宏引用完后如果不再需要就可以用%symdel删除。
2/将第一个宏和第二个宏写在一个宏内。
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
8#
 楼主| 发表于 2003-10-20 11:49:12 | 只看该作者
有道理,谢谢!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-5 18:29 , Processed in 0.186996 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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