OPTION SYMBOLGEN;
DATA A;
INPUT X Y K;
LABEL X='XX' Y='YY' K='KK';
CARDS;
1 2 3
;
RUN;
DATA B;
INPUT X Y K;
LABEL X='XXX' Y='YYY' K='ZZZ';
CARDS;
4 5 6
;
RUN;
PROC SQL;
SELECT
NAME,
LABEL
INTO:MA1 SEPARATED BY ' &TAB ',
:MA2 SEPARATED BY "' &TAB '"
FROM DICTIONARY.COLUMNS
WHERE LIBNAME='WORK' AND MEMNAME='A'
;
QUIT;
PROC SQL;
SELECT
NAME,
LABEL
INTO:MB1 SEPARATED BY ' &TAB ',
:MB2 SEPARATED BY "' &TAB '"
FROM DICTIONARY.COLUMNS
WHERE LIBNAME='WORK' AND MEMNAME='B'
;
QUIT;
%MACRO TIME;
data _null_;
length fid rc start stop time 8;
fid=fopen('sas2xl','s');
if (fid le 0) then do;
rc=system('start excel');
start=datetime();
stop=start+10;
do while (fid le 0);
fid=fopen('sas2xl','s');
time=datetime();
if (time ge stop) then fid=1;
end;
end;
rc=fclose(fid);
run;
%mend;
data _null_;
file sas2xl;
put '[workbook.insert(1)]';
;
run;
%MEND SHEET;
%MACRO DDE1(d1,d2);
%TIME
data _null_;
file sas2xl;
put '[file.close(false)]';
put '[new(1)]';
put '[error(false)]';
put '[save.as("D:\tt")]';
run;
%SHEET(1)
%SHEET(2)
data _null_;
file sas2xl;
put '[save]';
put '[file.close(false)]';
put '[quit]';
run;