I want to create a macro to rename all variables in sashelp.cars with suffix 1.
For eg. MODEL will be MODEL1.
PS: I Don't want to use renaming (eg. rename model = model1). I want to find count of variable in the dataset sashelp.cars and use do loop and then rename inside macro (also don't want to use variable name directly while renaming).
Any easy approach to do this?
You want to rename with using the RENAME statement or option? And without using the variable name?
This makes no sense at all.
I want to create a macro to rename all variables in sashelp.cars with suffix 1.
For eg. MODEL will be MODEL1.
PS: I Don't want to use renaming (eg. rename model = model1). I want to find count of variable in the dataset sashelp.cars and use do loop and then rename inside macro (also don't want to use variable name directly while renaming).
Any easy approach to do this?
@gahlot1999 wrote:
PS: I Don't want to use renaming (eg. rename model = model1). I want to find count of variable in the dataset sashelp.cars and use do loop and then rename inside macro (also don't want to use variable name directly while renaming).
Any easy approach to do this?
Why this restriction? Why are you saying I can only use certain parts of SAS to do this and not other parts of SAS?
You realize that you can't rename variables in SASHELP.CARS because users do not have WRITE permission to any SASHELP data sets. You could copy the data set into the WORK library.
Anyway, this is easily done without a macro and without specifying an explicit loop, but with the RENAME statement and with a single macro variable.
No macro needed, only a macro variable.
proc sql noprint;
select trim(name) !! "=" !! trim(name) !! "1" into :renames separated by " "
from dictionary.columns
where libname = "SASHELP" and memname = "CARS";
quit;
%put &renames.;The resulting macro variable can be used in a RENAME statement or RENAME= dataset option.
It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.
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.
