Hello!
My friend came to me with this issue and I wasn't sure how to unlock this one. I mentioned I would come on SAS communities to see if anyone could help me figure this out. The issue is he has a list that has numbers listed that when given dropped most of the leading zeros. I wasn't sure how to pad these within a sysfunc, I do know that the put / input functions work outside of sysfunc, but I read that putc and inputc are needed for macro values.
Thank you!
%let clients = '12345';
%let clientsb = %sysfunc(putc(%sysfunc(inputc(&clients,best7.)),z7.));
%put &clientsb;
@IgawaKei29 Hi, I think you are perhaps after this?
%let clients = 12345;
%let clientsb = %sysfunc(putn(%sysfunc(inputn(&clients,best7.)),z7.));
%put &=clientsb;
LOG:
27 %let clients = 12345;
28 %let clientsb = %sysfunc(putn(%sysfunc(inputn(&clients,best7.)),z7.));
29 %put &=clientsb;
CLIENTSB=0012345
30
@IgawaKei29 Hi, I think you are perhaps after this?
%let clients = 12345;
%let clientsb = %sysfunc(putn(%sysfunc(inputn(&clients,best7.)),z7.));
%put &=clientsb;
LOG:
27 %let clients = 12345;
28 %let clientsb = %sysfunc(putn(%sysfunc(inputn(&clients,best7.)),z7.));
29 %put &=clientsb;
CLIENTSB=0012345
30
Kind of need to show what the expected output should be.
Macro variables won't "drop" leading zero. Example:
%let a = 07; %put a is: &a;
So the idea would be to do back to the source of the values with leading zeroes and what ever "removed" them.
Likely someone is reading a value that should be character, such as account numbers that often have leading zero, and not paying attention to how they are reading them. Such as abdicating responsibility and letting a procedure like Proc Import read them and create numeric variables. Prevention in the first place removes a whole lot of headaches "fixing" things later.
And doing such fixes in the macro language often indicates a design flaw for the entire process. Such as placing quotes as part of a macro variable.
%let x =23; %let y = %sysfunc(putn(&x,z7.)); %put y is: &y.;
or
%let clients = 12345; %let clientsb = %sysfunc(putn(&clients,z7.)); %put &clientsb;
Generally it is poor idea to make quotes part of the value of a macro variable.
Ideally you'd be able to remove quotes from the macro variable which simplifies the problem. If you can't you can remove them using dequote.
%let clients = 12345;
%let clientsb = %sysfunc(putn(&clients,z7.));
%put &clientsb;
%let clients = '12345';
%let clientsb = %sysfunc(putn(%sysfunc(dequote(&clients)), z7.));
%put &clientsb;
@IgawaKei29 wrote:
Hello!
My friend came to me with this issue and I wasn't sure how to unlock this one. I mentioned I would come on SAS communities to see if anyone could help me figure this out. The issue is he has a list that has numbers listed that when given dropped most of the leading zeros. I wasn't sure how to pad these within a sysfunc, I do know that the put / input functions work outside of sysfunc, but I read that putc and inputc are needed for macro values.
Thank you!
%let clients = '12345'; %let clientsb = %sysfunc(putc(%sysfunc(inputc(&clients,best7.)),z7.)); %put &clientsb;
Like most posters, I don't believe that quotes are really part of the value. And if they are, @Reeza has shown you a function to remove them.
At any rate, you don't need any %SYSFUNCs to get the result. Just keep in mind that macro variable values are strings:
%let clients = 12345;
%let clientsb = %substr(0000000&clients, %length(&clients) + 1);
Quotes are not needed in macro variables. You need quotes in SAS code (and most languages) so the parser knows you meant a string and not a number. But the macro processor only works on text so no quotes are needed. And if you include them they are part of the value.
The INPUTC() function needs a character informat since it generates a character result but you have given it a numeric informat. The PUTC() functions needs a character format since it operates on character values but you have given it a numeric format. Since the %SYSFUNC() macro function does not surface the error messages your code just silently does nothing to the original string.
Note that there is no need to use the INPUTN() function to turn a string of digits into a number. Just use the string of digits in a place where a number is expected and it will be treated as a number. Also note that there is no "BEST" informat. If you use that name it is just translated into a request to use the default numeric informat. BEST is the name of a format that makes an attempt to convert a number into a string of characters in the best possible way to fit the width specified. But SAS only has one format for storing numbers, floating point, so there is no "best" way to convert the string into a number. Instead the string is just converted into THE number it represents.
Just use the PUTN() function to treat the string of digits as a number and convert it into a fixed length string of digits that represents the same number only padded with leading zeros.
%let clients = 12345 ;
%let clientsb = %sysfunc(putn(&clients,z7.));
Thank you @Tom @Astounding @Reeza @ballardw @novinosrin I really appreciate your insight on this. Gives us both a perspective on macros and understanding how to deploy them properly.
Join us for SAS Innovate 2025, our biggest and most exciting global event of the year, in Orlando, FL, from May 6-9. Sign up by March 14 for just $795.
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.