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

Hello,

 

is it possible in SAS to call a macro and write the macro at the end of the programm?

It works, but i would need to run the programm twice. Are there any other ideas?

 

For example:

%mymacro;


proc sql;

select id_discriminator, count(*)

   from work.macro_table

   group by 1;

quit;


%macro mymacro;

proc sql;

create table work.macro_table as

   select id_discriminator

      from data_have;

quit;

%mend;

 

 

 

Thanks in advance,

Martin

 

1 ACCEPTED SOLUTION

Accepted Solutions
SASKiwi
PROC Star

A macro has to be defined before it is called. One option is to put your macro into an AUTOCALL macro library from where it is defined automatically when referenced in your program. 

View solution in original post

4 REPLIES 4
SASKiwi
PROC Star

A macro has to be defined before it is called. One option is to put your macro into an AUTOCALL macro library from where it is defined automatically when referenced in your program. 

RW9
Diamond | Level 26 RW9
Diamond | Level 26

You can put a macro definition anywhere, so long as it appears *before* the call to that macro.  Autocall library is one option.  Saving to a text file and using %include at the top of your program is another.  What exactly are you attemting to do?  

Mart_Schm
Calcite | Level 5

my goal was (is) to make the code more readable.
I read now about autocall librarys and i think this works fine for me.

Thanks for your answer

RW9
Diamond | Level 26 RW9
Diamond | Level 26

Easiest ways to make code more readable other than using good coding practices (such as consistent casing, indentation, finishing blocks etc.) would be to reduce the use of macro language.  Macro language is an additional tool which is only there to remove the need to repeat code, however it is vastly abused.  There should almost never be a time where you resort to macro as you can't do something in Base SAS.  Also, don't wrap self explanatory code in macros, too often I see:

%macro dosomething ();

proc sort data=abc;data abc; set x=1;

%mend;

 

This code is a total waste of space, and obfuscates it totally to no additional value.

 

The reason I mention this is because, from a readability sense, so long as a macro has followed SDLC processes, you will have a function design specification, along with probably a user guide.  So seeing the code should not really be necessary because of the good documentation.  However in 99% of the macro libraries I come across there is zero documentation, poor programming standards, and plenty of obfuscation.

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

Creating Custom Steps in SAS Studio

Check out this tutorial series to learn how to build your own steps in SAS Studio.

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
  • 4 replies
  • 1811 views
  • 1 like
  • 3 in conversation