【发布时间】:2017-01-06 12:56:49
【问题描述】:
我正在尝试使用以下宏编写 ods 输出:
%let class1=X1 X2
%let &new_var=X3 X4
options mprint mlogic symbolgen;
%macro LogitBoot(data = , dv = , iv = ,class=, n = );
proc sql noprint;
create table logit_result
(iv char(10), prob num format = 6.4,
sig1 num format = 4., sig2 num format = 4.,
sig3 num format = 4., sig4 num format = 4.);
select count(*) into :sample from &data;
quit;
%do i = 1 %to &n;
proc surveyselect data = training method = urs out = &data._tmp n = &sample
noprint;
run;
proc logistic data = &data._tmp desc;
freq numberhits;
class &class;
model &dv = &iv;
ods output type3 = model_tmp;
run;
proc sql;
insert into logit_result
select
upcase(effect) as iv, ProbChiSq as prob,
case when ProbChiSq <= 0.01 then 1 else 0 end as sig1,
case when ProbChiSq > 0.01 and ProbChiSq <= 0.05 then 1 else 0 end as sig2,
case when ProbChiSq > 0.05 and ProbChiSq <= 0.1 then 1 else 0 end as sig3,
case when ProbChiSq > 0.1 then 1 else 0 end as sig4
from model_tmp;
quit;
%end;
proc summary data = logit_result nway;
class iv;
output out = out_table (drop = _type_ rename = (_freq_ = count))
sum(sig1) = sum(sig2) = sum(sig3) = sum(sig4) = ;
run;
%mend LogitBoot;
%LogitBoot(data =training, dv = Target, class=&class1,iv =&new_var, n = 2); 但我不断收到以下警告:
警告:未创建输出“type3”。确保输出对象名称、标签或路径拼写正确。另外,验证 适当的过程选项用于生成请求的输出对象。例如,验证 不使用 NOPRINT 选项。
有人可以帮忙吗?
【问题讨论】:
-
根据文档 type3 不是一个合适的 ods 表名 (support.sas.com/documentation/cdl/en/statug/63962/HTML/default/…)
-
对不起,我实际上将它用于 proc 逻辑,但它仍然没有生成
-
你能发布示例数据和工作代码吗?您当前的代码顶部有额外的 PROC 语句。对它定义的宏没有任何调用。此外,您需要在 proc 运行之前而不是之后设置 ODS OUTPUT。
-
嗨,汤姆,我已经编辑了我的帖子,您现在可以看一下吗?