mirror of
https://github.com/sasjs/core.git
synced 2025-12-10 22:14:35 +00:00
145 lines
5.0 KiB
SAS
145 lines
5.0 KiB
SAS
/**
|
|
@file
|
|
@brief Export format definitions
|
|
@details Formats are exported from the first (if any) catalog entry in the
|
|
FMTSEARCH path.
|
|
|
|
Formats are taken from the library / dataset reference and / or a static
|
|
format list.
|
|
|
|
Example usage:
|
|
|
|
%mp_getformats(lib=sashelp,ds=prdsale,outsummary=work.dictable)
|
|
|
|
@param [in] lib= (0) The libref for which to return formats.
|
|
@todo Enable exporting of formats for an entire library
|
|
@param [in] ds= (0) The dataset from which to obtain format definitions
|
|
@param [in] fmtlist= (0) A list of additional format names
|
|
@param [out] outsummary= (work.mp_getformats_summary) Output dataset
|
|
containing summary definitions - structure taken from dictionary.formats as
|
|
follows:
|
|
|libname:$8.|memname:$32.|path:$1024.|objname:$32.|fmtname:$32.|fmttype:$1.|source:$1.|minw:best.|mind:best.|maxw:best.|maxd:best.|d
|
|
efw:best.|defd:best.|
|
|
|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
|
|||||$|F|B|1|0|32767|0|1|0|
|
|
|||||$|I|B|1|0|32767|0|1|0|
|
|
|||/opt/sas/sas9/SASHome/SASFoundation/9.4/sasexe|UWIANYDT|$ANYDTIF|I|U|1|0|60|0|19|0|
|
|
|||/opt/sas/sas9/SASHome/SASFoundation/9.4/sasexe|UWFASCII|$ASCII|F|U|1|0|32767|0|1|0|
|
|
|||/opt/sas/sas9/SASHome/SASFoundation/9.4/sasexe|UWIASCII|$ASCII|I|U|1|0|32767|0|1|0|
|
|
|||/opt/sas/sas9/SASHome/SASFoundation/9.4/sasexe|UWFBASE6|$BASE64X|F|U|1|0|32767|0|1|0|
|
|
|||/opt/sas/sas9/SASHome/SASFoundation/9.4/sasexe|UWIBASE6|$BASE64X|I|U|1|0|32767|0|1|0|
|
|
|||/opt/sas/sas9/SASHome/SASFoundation/9.4/sasexe|UWFBIDI|$BIDI|F|U|1|0|32767|0|1|0|
|
|
|||||$BINARY|F|B|1|0|32767|0|8|0|
|
|
|||||$BINARY|I|B|1|0|32767|0|8|0|
|
|
|
|
@param [out] outdetail= (0) Provide an output dataset in which to export all
|
|
the custom format definitions (from proc format CNTLOUT). Definitions:
|
|
https://support.sas.com/documentation/cdl/en/proc/61895/HTML/default/viewer.htm#a002473477.htm
|
|
Sample data:
|
|
|
|
|NAME $|LENGTH 8|VARNUM 8|LABEL $|FORMAT $49|TYPE $1 |DDTYPE $|
|
|
|---|---|---|---|---|---|---|
|
|
|AIR|8|2|international airline travel (thousands)|8.|N|NUMERIC|
|
|
|DATE|8|1|DATE|MONYY.|N|DATE|
|
|
|REGION|3|3|REGION|$3.|C|CHARACTER|
|
|
|
|
<h4> SAS Macros </h4>
|
|
@li mf_dedup.sas
|
|
@li mf_getfmtlist.sas
|
|
@li mf_getfmtname.sas
|
|
@li mf_getquotedstr.sas
|
|
@li mf_getuniquename.sas
|
|
|
|
|
|
<h4> Related Macros </h4>
|
|
@li mp_getformats.test.sas
|
|
|
|
@version 9.2
|
|
@author Allan Bowe
|
|
|
|
**/
|
|
|
|
%macro mp_getformats(lib=0
|
|
,ds=0
|
|
,fmtlist=0
|
|
,outsummary=work.mp_getformats_summary
|
|
,outdetail=0
|
|
);
|
|
|
|
%local i fmt allfmts tempds fmtcnt;
|
|
|
|
%if "&fmtlist" ne "0" %then %do i=1 %to %sysfunc(countw(&fmtlist,,%str( )));
|
|
/* ensure format list contains format _name_ only */
|
|
%let fmt=%scan(&fmtlist,&i,%str( ));
|
|
%let fmt=%mf_getfmtname(&fmt);
|
|
%let allfmts=&allfmts &fmt;
|
|
%end;
|
|
|
|
%if &ds=0 and &lib ne 0 %then %do;
|
|
/* grab formats from library */
|
|
/* to do */
|
|
%end;
|
|
%else %if &ds ne 0 and &lib ne 0 %then %do;
|
|
/* grab formats from dataset */
|
|
%let allfmts=%mf_getfmtlist(&lib..&ds) &allfmts;
|
|
%end;
|
|
|
|
/* ensure list is unique */
|
|
%let allfmts=%mf_dedup(%upcase(&allfmts));
|
|
|
|
/* create summary table */
|
|
%if %index(&outsummary,.)=0 %then %let outsummary=WORK.&outsummary;
|
|
proc sql;
|
|
create table &outsummary as
|
|
select * from dictionary.formats
|
|
where fmtname in (%mf_getquotedstr(&allfmts,quote=D))
|
|
and fmttype='F';
|
|
|
|
%if "&outdetail" ne "0" %then %do;
|
|
/* ensure base table always exists */
|
|
proc sql;
|
|
create table &outdetail(
|
|
FMTNAME char(32) label='Format name'
|
|
,START char(16) label='Starting value for format'
|
|
,END char(16) label='Ending value for format'
|
|
,LABEL char(256) label='Format value label'
|
|
,MIN num length=3 label='Minimum length'
|
|
,MAX num length=3 label='Maximum length'
|
|
,DEFAULT num length=3 label='Default length'
|
|
,LENGTH num length=3 label='Format length'
|
|
,FUZZ num label='Fuzz value'
|
|
,PREFIX char(2) label='Prefix characters'
|
|
,MULT num label='Multiplier'
|
|
,FILL char(1) label='Fill character'
|
|
,NOEDIT num length=3 label='Is picture string noedit?'
|
|
,TYPE char(1) label='Type of format'
|
|
,SEXCL char(1) label='Start exclusion'
|
|
,EEXCL char(1) label='End exclusion'
|
|
,HLO char(13) label='Additional information'
|
|
,DECSEP char(1) label='Decimal separator'
|
|
,DIG3SEP char(1) label='Three-digit separator'
|
|
,DATATYPE char(8) label='Date/time/datetime?'
|
|
,LANGUAGE char(8) label='Language for date strings'
|
|
);
|
|
/* grab the location of each format */
|
|
%let fmtcnt=0;
|
|
data _null_;
|
|
set &outsummary;
|
|
if not missing(libname);
|
|
x+1;
|
|
call symputx(cats('fmtloc',x),cats(libname,'.',memname),'l');
|
|
call symputx(cats('fmtname',x),fmtname,'l');
|
|
call symputx('fmtcnt',x,'l');
|
|
run;
|
|
/* export each format and append to the output table */
|
|
%let tempds=%mf_getuniquename(prefix=mp_getformats);
|
|
%do i=1 %to &fmtcnt;
|
|
proc format library=&&fmtloc&i CNTLOUT=&tempds;
|
|
select &&fmtname&i;
|
|
run;
|
|
proc append base=&outdetail data=&tempds;
|
|
run;
|
|
%end;
|
|
%end;
|
|
|
|
%mend mp_getformats; |