SAS中文论坛

标题: 求教:如何进行宏变量计算 [打印本页]

作者: shiyiming    时间: 2003-10-17 14:39
标题: 求教:如何进行宏变量计算
%let numRecordCount=11;
%let numBaseTableCount=19;
%let numPercentage=%eval((&numRecordCount/&numBaseTableCount)*100);
%put &numPercentage;
我觉得没有错啊,为什么结果是0?
作者: shiyiming    时间: 2003-10-17 16:10
标题: 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);
作者: shiyiming    时间: 2003-10-17 16:40
COOL,谢谢老大!
但是如果numRecordCount和numBaseTableCount都是由select count(*) into :numRecordCount from TableA和select count(*) into :numBaseTableCount from BaseTable得来的,结果似乎还是不对。有何良策?
作者: shiyiming    时间: 2003-10-18 00:10
是这个意思吗?好象没错呀!


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;
作者: shiyiming    时间: 2003-10-18 09:16
没错,就是这个意思,你的能跑正确。但在我实际程序中的确不成功。
不过没关系,实在不行,我用data step来计算,再用call symput赋值。
谢谢!
作者: shiyiming    时间: 2003-10-20 09:08
标题: to Jerry兄
这段代码测试过吗??
作者: shiyiming    时间: 2003-10-20 11:41
[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/将第一个宏和第二个宏写在一个宏内。
作者: shiyiming    时间: 2003-10-20 11:49
有道理,谢谢!




欢迎光临 SAS中文论坛 (http://mysas.net/forum/) Powered by Discuz! X3.2