SAS中文论坛
标题:
如何实现一个宏,计算一个数据集里某个属性列的最大值
[打印本页]
作者:
shiyiming
时间:
2008-11-17 23:17
标题:
如何实现一个宏,计算一个数据集里某个属性列的最大值
比如说现在有一个名为temp的数据集,想获得temp中属性列b的最大值,也就是这一列的最大值,我编了下面的函数,可怎么发现max始终是0呢,望高手指点,谢谢!
%MACRO maxvalue;
%global max base;
%let base;
%let max=0;
data _null_;
set temp;
call symput('base',b);
%if &max < &base %then %let max = %eval(&base+0);
run;
%MEND maxvalue;
作者:
shiyiming
时间:
2008-11-18 03:15
标题:
Re: 如何实现一个宏,计算一个数据集里某个属性列的最大值
描述性统计分析proc univariate就可以
作者:
shiyiming
时间:
2008-11-18 16:43
标题:
Re: 如何实现一个宏,计算一个数据集里某个属性列的最大值
很多方法!
ex.
proc sql;
select max(b) into :maxvalue from temp;
quit;
%put &maxvalue;
作者:
shiyiming
时间:
2008-11-19 10:34
标题:
Re: 如何实现一个宏,计算一个数据集里某个属性列的最大值
我先根据个人的理解,分析下lz的程序,告诉你问题出在哪里,仅供参考,赫赫!~
%MACRO maxvalue;
%global max base;
%let base;/*首先这句,必须给base赋值*/
%let max=0;
data _null_;
set temp;
call symput('base',b);/*其次这句,这是错误的关键,因为传递的是当前值,当前值是什么?是最后一个值*/
%if &max < &base %then %let max = %eval(&base+0);/*最后max当然返回的是b列的最后一个值了*/
run;
%MEND maxvalue;
根据ls的思路我自己写了,近一个参考!~
%MACRO maxvalue;
%global max base;
data _null_;
set temp;
retain max;
if _n_=1 then max=b;
else max=max(max,b);
call symput('max',max);
run;
%MEND maxvalue;
%maxvalue;
%put &max;
欢迎光临 SAS中文论坛 (https://mysas.net/forum/)
Powered by Discuz! X3.2