BookmarkSubscribeRSS Feed
SASPhile
Quartz | Level 8
The following %let statement goes through iterations.How to convert the macro variables to numeric?

%LET VGROUP&I = "&&GROUP&I";
2 REPLIES 2
Reeza
Super User
Macro variables are always stored as characters.

If you want it resolved to numeric you can apply a format where you would resolve the variable, using sysfunc and inputn functions.

See
http://support.sas.com/documentation/cdl/en/mcrolref/61885/HTML/default/viewer.htm#z3514sysfunc.htm

HTH
Cynthia_sas
Diamond | Level 26
Hi:
And, as an additional comment, it is hardly ever a good idea to "prequote" macro variables in a %LET statement. In the code snippet that you showed, the macro variable would contain the resolved value of &&GROUP&I, including the quotes. This may or may not be appropriate and could cause quoting problems depending on your usage of &VGROUP1, &VGROUP2, etc.

cynthia

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