Hello,
I am trying to run a loop in a Macro program.
I would like to go back to the loop if there is no observation in test2 . Is there any way for that ? Thank you very much.
%macro test ;
data test1;
set test;
where ;
run;
%do i= 1 %to 41;
data test2;
set test1;
where .....;
..........
%end;
%mend;
Here is one way. Does it suit you?
%do i= 1 %to 41; proc sql; create table test2 as select * from test1 where .....; run; %if &sqlobs=0 %then %goto next_iteration; .......... %next_iteration: %end;
April 27 – 30 | Gaylord Texan | Grapevine, Texas
Walk in ready to learn. Walk out ready to deliver. This is the data and AI conference you can't afford to miss.Register now and lock in 2025 pricing—just $495!
Register now
Still thinking about your presentation idea? The submission deadline has been extended to Friday, Nov. 14, at 11:59 p.m. ET.
Submit your proposal!
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.
Browse our catalog!