下面是宏代碼.....如何爲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