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

 

I ran the following program using the SAS EG.  I defined a macro run_macro in the main program.  I created a separate program macro_1.sas in /foldername/ folder which contains a macro macro_1.  After I make changes in macro_1.sas and run the main program, why is the SAS keep running the same codes before the changes? It runs the program correctly only if I close the SAS, re-open and run. Does someone know why?   

 

options pagesize=59  mautosource  sasautos="/foldername/";

%macro run_macro;

%* ;

  %macro_1;

%* ;

%mend run_macro;

%run_macro;

 

1 ACCEPTED SOLUTION

Accepted Solutions
ballardw
Super User

You may also need to set the option MREPLACE to enable a previously defined macro to be replaced with the newer version.

View solution in original post

2 REPLIES 2
Astounding
PROC Star

You are observing standard behavior.  SAS does not look for the macro definition each time you use the macro.  It only searches for the macro definition if the macro is not yet defined.  So you have changed the definition, but SAS doesn't look for the new definition.

 

For a contining EG session, try adding a %INCLUDE statement to bring in the file holding the revised macro definition.  %INCLUDE can be placed either inside or outside a macro definition, wherever you see fit to redefine a macro.

ballardw
Super User

You may also need to set the option MREPLACE to enable a previously defined macro to be replaced with the newer version.

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

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
  • 1245 views
  • 0 likes
  • 3 in conversation