Hi All,
I have data as below.
Values
LAB_RESULT1
LAB_UNITS
LAB_HI1
I want to find out the string which contain numbers at any position in string.
I need the same in macro only and in macro anydigit is not working for me.
Regards,
Rajesh
Yes, anydigit() will not work straight off, you could put it in %sysfunc(), but that has limited functions it supports. The simple point here is the Macro language is NOT the programming language. It is a text generation tool. Base SAS is THE programming language, it has all the data types, the functions, the procedures. Use the right tool for the right job, you wouldn't believe how many questions take the form "Have to use macro, not working", and the answer is always use Base SAS. If you abosultely have to have the string in macro then:
data _null_;
  if anydigit("&VALUE.") then res=1;
  else res=0;
  call symput('res',res);
run;
...
%if &res. %then %do;
...
This combines Base SAS step with macro variables.
Yes, anydigit() will not work straight off, you could put it in %sysfunc(), but that has limited functions it supports. The simple point here is the Macro language is NOT the programming language. It is a text generation tool. Base SAS is THE programming language, it has all the data types, the functions, the procedures. Use the right tool for the right job, you wouldn't believe how many questions take the form "Have to use macro, not working", and the answer is always use Base SAS. If you abosultely have to have the string in macro then:
data _null_;
  if anydigit("&VALUE.") then res=1;
  else res=0;
  call symput('res',res);
run;
...
%if &res. %then %do;
...
This combines Base SAS step with macro variables.
You will need to find a new plan.
Macro language does not process values within a SAS data set. You would have to first create a set of macro variables from the data values, and then macro language could examine them one by one.
And to add to @Astounding's very important comment, you would have to multiple the complexity severely if there are other pieces of information needed such as the values of other variables.
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.
