全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
1319 2
2014-03-09
我运行了下面这段macro,没有生成任何文件,请教一下,是哪个环节出错了?用的数据v23在附件里。非常感谢提点!

另:怎么定义第一部分里的varlist=, 使其能够实现下面两种情况:(1)比如我有100个var,不需要逐一列出就可引用全部的var ; (2) 我只想引用其中的98个,剩下的两个var2和var99我希望剔除出去。
关于var的引用,我了解这两种方式:var _all_; 或者mean=mean(of _all_);

*1;
%macro median(mydata =work.v23, varlist=read write math science socst, medname = median);
*2;
data _null_;
      if 0 then set &mydata nobs = nobs;
     call symput('nobs', nobs);
run;
*3;
proc transpose data = &mydata out = aaa;
      var &varlist;
run;
*4;
proc univariate data = aaa noprint;
     var col1 - col&nobs;
     output out = bbb  median = col1 - col&nobs;
run;
*5;
proc transpose data = bbb  out = ccc;
var _all_;
run;
*6;
data v25;
     merge &mydata ccc(keep = col1  rename = (col1 = &medname));
run;
%mend median;


v23.rar
大小:(760 Bytes)

 马上下载

本附件包括:

  • v23.sas7bdat



二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

全部回复
2014-3-9 10:22:41
在&nobs放在%left里面就可以了,否则解析出来的&nobs有leading blanks
proc univariate data = aaa noprint;
/*     var col1 - col&nobs; */
     var col1 - col%left(&nobs);
/*     output out = bbb  median = col1 - col%left(&nobs);*/
     output out = bbb  median = col1 - col%left(&nobs);
run;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2014-3-9 23:43:05
多谢教授提点!问题解决了,你给的修改起作用!
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群