SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 650|回复: 3
打印 上一主题 下一主题

如何实现一个宏,计算一个数据集里某个属性列的最大值

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2008-11-17 23:17:58 | 只看该作者

如何实现一个宏,计算一个数据集里某个属性列的最大值

比如说现在有一个名为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;
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2008-11-18 03:15:44 | 只看该作者

Re: 如何实现一个宏,计算一个数据集里某个属性列的最大值

描述性统计分析proc univariate就可以
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2008-11-18 16:43:03 | 只看该作者

Re: 如何实现一个宏,计算一个数据集里某个属性列的最大值

很多方法!
ex.
proc sql;
  select max(b) into :maxvalue from temp;
quit;
%put &maxvalue;
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2008-11-19 10:34:17 | 只看该作者

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;
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-5 05:15 , Processed in 0.068024 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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