data x ;
set % do i = 1 , 2 , 3 , 8 , 10 ;
xyz&i
%end; ;
run;
Hi guyz, I need to append some datasets which ends with a number like this scenario above. But , when i run this code am getting this error "%to note found, macro is not compiled" . Please help me in this situation
%DO is not as flexible as DO.
Make a list and loop over an index into the list.
Note: the %UNQUOTE() is because sometimes the parser can get confused by this type of syntax and treat the XYZ and %SCAN() as separate tokens.
%let suffix=1 2 3 8 10;
data x ;
set
%do i=1 %to %sysfunc(countw(&suffix,%str( )));
%unquote(xyz%scan(&suffix,&i,%str( )))
%end;
;
run;
Don't miss out on SAS Innovate - Register now for the FREE Livestream!
Can't make it to Vegas? No problem! Watch our general sessions LIVE or on-demand starting April 17th. Hear from SAS execs, best-selling author Adam Grant, Hot Ones host Sean Evans, top tech journalist Kara Swisher, AI expert Cassie Kozyrkov, and the mind-blowing dance crew iLuminate! Plus, get access to over 20 breakout sessions.
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.