when I merely used macro:
%extracTable();
there is no error..
however when I am using :
data _null_;
if 1=1
then %extracTable();
else put @@@do not insert@@@;
run;
it return :
error:unquote array:Execute
error:388-105
error 76-322
error:180-322
why and how to fix it...I am weak at sas Marco grammar..thank you
My preference is to just let it stand as is. I say that because the question has changed somewhat. One of my pet peeves is questions that morph as they are solved, and I would much rather avoid that.
"OK, that worked but what I really need is to ..."
"OK, that worked. The next step is to ..."
Let this part stand as a separate question, and chips fall where they may.
I'm not sure I should reply. You seem unwilling or perhaps unable to take my advice on other questions. So last attempt:
data _null_;
if 1=1
then call execute('%nrstr(%extracTable())');
else put '@@@do not insert@@@';
run;
It's not clear why you need an ELSE condition when 1=1 must always be true, but perhaps this is a simplification of a more complex problem.
@Astounding I didn't see this thread was the continuation of another thread.
Maybe should it be marked as spam to remove duplicates?
My preference is to just let it stand as is. I say that because the question has changed somewhat. One of my pet peeves is questions that morph as they are solved, and I would much rather avoid that.
"OK, that worked but what I really need is to ..."
"OK, that worked. The next step is to ..."
Let this part stand as a separate question, and chips fall where they may.
For someone to diagnose the error, you will need to post the log.
@Astounding wrote:
For someone to diagnose the error, you will need to post the log.
And perhaps the actual macro code that is called.
And run the code with: Options mprint symbolgen mlogic;
Then post the log with the code and error messages into a code box opened using the forum {I} menu icon. Error messages often have indicators of position where SAS identified the error but the main message windows of this forum will reformat text resulting in moved indicators. The code box will preserve text as copied from the log so the diagnostics are in the correct position.
Note that errors caused by macro code do not display in the most helpful manner unless the MPRINT option is set.
Are you ready for the spotlight? We're accepting content ideas for SAS Innovate 2025 to be held May 6-9 in Orlando, FL. The call is open until September 25. Read more here about why you should contribute and what is in it for you!
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.