I am creating a stored process which uses the streaming output to generate a result in various format. One of the desired Output is to give business user ability to download result in form of SAS dataset so that they don't have to worry about importing the spreadsheet into sas everytime.
Please guide me with the best approach. Thanks
Try something like this:
* Set up a test table in WORK, but could be a permanent library;
%let MYLIB=work;
data &MYLIB..class; set sashelp.class; run;
* Write the data set to _WEBOUT;
%let RV=%sysfunc(appsrv_header(Content-type,application/x-sas-data));
%let RV=%sysfunc(appsrv_header(Content-disposition,%str(attachment; filename="Class.sas7bdat")));
filename temp "%sysfunc(pathname(&MYLIB))\class.sas7bdat";
data _null_;
infile temp recfm=f lrecl=1;
file _webout recfm=n;
input;
put _infile_;
run;
Vince DelGobbo
SAS R&D
Try something like this:
* Set up a test table in WORK, but could be a permanent library;
%let MYLIB=work;
data &MYLIB..class; set sashelp.class; run;
* Write the data set to _WEBOUT;
%let RV=%sysfunc(appsrv_header(Content-type,application/x-sas-data));
%let RV=%sysfunc(appsrv_header(Content-disposition,%str(attachment; filename="Class.sas7bdat")));
filename temp "%sysfunc(pathname(&MYLIB))\class.sas7bdat";
data _null_;
infile temp recfm=f lrecl=1;
file _webout recfm=n;
input;
put _infile_;
run;
Vince DelGobbo
SAS R&D
SAS Innovate 2025 is scheduled for May 6-9 in Orlando, FL. Sign up to be first to learn about the agenda and registration!
Learn how use the CAT functions in SAS to join values from multiple variables into a single value.
Find more tutorials on the SAS Users YouTube channel.
Ready to level-up your skills? Choose your own adventure.