全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
3145 11
2015-02-09

这段宏程序运行不了,也没有报错,不知道是哪里的问题,请教高手指教!



%macro nvardescrip(data =trans , out = like);

proc contents data=&data out=a0 noprint;

run;  

proc sql;

select NAME into : nvarsseperated by '  '  from a0 where TYPE = 1;

quit;

%let i = 1;

%do %until(%scan(&nvars, &i, '  ') = );

%let varname = %scan(&nvars, &i, '  ');

%end;

proc univariate data = &data noprint;

var&varname;

output out = a1 nmiss = nmiss mean = mean std = std min = min Q1 = Q1 median = median Q3 = Q3 max = max;

run;

data a1;

retain name nmiss mean std min Q! median Q3 max;

set a1;

length name $15.;

name = "&varname";

label name = "变量名" nmiss = "缺失观察数" mean = "均值" std = "标准偏差" min = "最小值" Q1 = "下四分位"

median = "中位数" Q3 = "上四分位数" max = "最大值";

run;

%if &i = 1 %then %do;

data&out; set a1; run;

%end;

%else %do;

data &out; set &out; run;


%mend;


二维码

扫码加我 拉你入群

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

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

全部回复
2015-2-9 14:47:44
%scan(&nvars, &i, %str( ));
二维码

扫码加我 拉你入群

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

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

2015-2-9 15:06:40
liudeng2005 发表于 2015-2-9 14:47
%scan(&nvars, &i, %str( ));
还是不行!
二维码

扫码加我 拉你入群

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

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

2015-2-9 15:39:58
%macro nvardescrip(data =trans , out = like);

proc contents data=&data out=a0 noprint;

run;  


proc sql;

select distinct NAME into : var1-:var99999 from a0 where TYPE = 1;

quit;

%let tn=&sqlobs;
%do  i = 1 to &tn;  


proc univariate data = &data noprint;

var&varname;

output out = a1 nmiss = nmiss mean = mean std = std min = min Q1 = Q1 median = median Q3 = Q3 max = max;

run;


data a1;

retain name nmiss mean std min Q! median Q3 max;

set a1;

length name $15.;

name = "&&var&i";

label name = "变量名" nmiss = "缺失观察数" mean = "均值" std = "标准偏差" min = "最小值" Q1 = "下四分位"

median = "中位数" Q3 = "上四分位数" max = "最大值";

run;


%if &i = 1 %then %do;

data&out; set a1; run;

%end;

%else %do;

data &out; set &out a1; run;

%end;
%end;




%mend;
二维码

扫码加我 拉你入群

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

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

2015-2-9 16:53:59
liudeng2005 发表于 2015-2-9 15:39
%macro nvardescrip(data =trans , out = like);

proc contents data=&data out=a0 noprint;
还是不行,不报错,也不运行
二维码

扫码加我 拉你入群

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

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

2015-2-9 16:55:55
。。。


%nvardescrip()
二维码

扫码加我 拉你入群

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

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

点击查看更多内容…
相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

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