下面是宏代码.....如何为sas数据集中的每个观测值执行一个宏?
libname myfmt "&FBRMrootPath./Formats";
%macro CreateFormat(DSN,Label,Start,fmtname,type);
options mprint mlogic symbolgen;
%If &type='n' %then %do;
proc sort data=&DSN out=Out; by &Label;
Run;
Data ctrl;
set Out(rename=(&Label=label &Start=start)) end=last;
retain fmtname &fmtname type &type;
output;
If last then do;
hlo='O';
label='*ERROR';
output;
End;
Run;
%End;
%Else %do;
proc sort data=&DSN out=Out; by &Start;
Run;
Data ctrl;
set Out(rename=(&Start=label &Label=start)) end=last;
retain fmtname &fmtname type &type;
output;
If last then do;
hlo='O';
label='*ERROR';
output;
End;
Run;
%End;
proc format library=myfmt cntlin=ctrl;
Run;
%Mend CreateFormat;
这里是控制数据集,通过它上面的宏应用于所述数据集的每个观测和观测值的值来运行是varibales输入的代码在宏...
Data OPER.format_control;
Input DSN :$12. Label :$15. Start :$15. fmtName :$8. type :$1. fmt_Startdt :mmddyy. fmt_Enddt :mmddyy.;
format fmt_Startdt fmt_Enddt date9.;
Datalines;
ssin.prd prd_nm prd_id mealnm n . 12/31/9999
ssin.prd prd_id prd_nm mealid c . 12/31/9999
ssin.fac fac_nm onesrc_fac_id fac1SRnm n . 12/31/9999
ssin.fac fac_nm D3_fac_id facD3nm n . 12/31/9999
ssin.fac onesrc_fac_id D3_fac_id facD31SR n . 12/31/9999
oper.wrkgrp wrkgrp_nm wrkgrp_id grpnm n . 12/31/9999
;
我已经发布了一个示例调用执行的解决方案。这是否会以与您的解决方案不同的顺序运行宏的迭代? – user667489 2013-12-15 00:02:30
调用执行将在您的解决方案中以正确的顺序在宏步骤中运行。所以不用担心。然而,调用执行有时候会以一种意想不到的顺序运行这个简单的事实对我来说是可怕的,我现在完全避开它。以下是讨论此问题的一篇论文:http://www2.sas.com/proceedings/sugi22/CODERS/PAPER70.PDF 请参见第2/3页的“调用宏的示例”一节。 – 2014-07-01 17:50:04