BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
rajat051984
Fluorite | Level 6

I am trying to create some macro variables for multiple months as follows:

%let datep = date();

data _null_;

set b (obs=1);

prv1mnt = put(intnx('month',&datep.,-1,'beginning'),monyy7.);

call symput('prv1mntm',prv1mnt);

prev_1_mon_dt =intnx('month',&datep.,-1,'beginning');

prev_1_mon = year(prev_1_mon_dt)*100 + month(prev_1_mon_dt);

call symput('pr1mn',prev_1_mon);

run;

I need to do the above processing for last 12 months. Can it be done through loop?

1 ACCEPTED SOLUTION

Accepted Solutions
Reeza
Super User

Not 100% sure what you're asking, but wouldn't a macro do loop work?

%do i=1 %to 12;

%let datep = %sysfunc(intnx(month, %sysfunc(date()), -1*&i, b));


*rest of code;


%end;



View solution in original post

2 REPLIES 2
Reeza
Super User

Not 100% sure what you're asking, but wouldn't a macro do loop work?

%do i=1 %to 12;

%let datep = %sysfunc(intnx(month, %sysfunc(date()), -1*&i, b));


*rest of code;


%end;



rajat051984
Fluorite | Level 6

Thanks Reeza.

How to Concatenate Values

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.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 2 replies
  • 1149 views
  • 0 likes
  • 2 in conversation