<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Incorrect macro logic in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Incorrect-macro-logic/m-p/180045#M34414</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I have a macro that is looping through datafiles from different years for a proc mean. I want it to run with a different var statement depending on which year it is currently looping through.&amp;nbsp; At the moment, my code looks like this:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%macro varcheck;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %do i = &amp;amp;yrmin %to &amp;amp;yrmax;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %let yr = %substr(&amp;amp;i.,3,2);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; proc means n mean median max data=&amp;amp;lib..&amp;amp;stem.&amp;amp;yr.;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %if 2000 &amp;lt;= &amp;amp;i &amp;lt;= 2011 %then&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; vars &lt;EM&gt;variables&lt;/EM&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %else %if 2012 &amp;lt;= &amp;amp;i &amp;lt;= 2013 %then&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; vars &lt;EM&gt;other variables&lt;/EM&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; run;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %end;&lt;/P&gt;&lt;P&gt;%mend varcheck;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%varcheck;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;When I run the code, however, the program returns the following on years 2012 and 2013:&lt;/P&gt;&lt;P&gt;SYMBOLGEN:&amp;nbsp; Macro variable I resolves to 2012&lt;/P&gt;&lt;P&gt;MLOGIC(VARCHECK):&amp;nbsp; %IF condition 2000 &amp;lt;= &amp;amp;i &amp;lt;= 2011 is TRUE&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;It works if I replace the if conditions with &amp;amp;i = 2000 or &amp;amp;i = 2001 etc., but that can get pretty cumbersome. Is there a way to get this to resolve correctly, or am I stuck with the clunky way?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Tue, 15 Jul 2014 15:59:06 GMT</pubDate>
    <dc:creator>scify</dc:creator>
    <dc:date>2014-07-15T15:59:06Z</dc:date>
    <item>
      <title>Incorrect macro logic</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Incorrect-macro-logic/m-p/180045#M34414</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I have a macro that is looping through datafiles from different years for a proc mean. I want it to run with a different var statement depending on which year it is currently looping through.&amp;nbsp; At the moment, my code looks like this:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%macro varcheck;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %do i = &amp;amp;yrmin %to &amp;amp;yrmax;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %let yr = %substr(&amp;amp;i.,3,2);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; proc means n mean median max data=&amp;amp;lib..&amp;amp;stem.&amp;amp;yr.;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %if 2000 &amp;lt;= &amp;amp;i &amp;lt;= 2011 %then&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; vars &lt;EM&gt;variables&lt;/EM&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %else %if 2012 &amp;lt;= &amp;amp;i &amp;lt;= 2013 %then&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; vars &lt;EM&gt;other variables&lt;/EM&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; run;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %end;&lt;/P&gt;&lt;P&gt;%mend varcheck;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%varcheck;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;When I run the code, however, the program returns the following on years 2012 and 2013:&lt;/P&gt;&lt;P&gt;SYMBOLGEN:&amp;nbsp; Macro variable I resolves to 2012&lt;/P&gt;&lt;P&gt;MLOGIC(VARCHECK):&amp;nbsp; %IF condition 2000 &amp;lt;= &amp;amp;i &amp;lt;= 2011 is TRUE&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;It works if I replace the if conditions with &amp;amp;i = 2000 or &amp;amp;i = 2001 etc., but that can get pretty cumbersome. Is there a way to get this to resolve correctly, or am I stuck with the clunky way?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 15 Jul 2014 15:59:06 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Incorrect-macro-logic/m-p/180045#M34414</guid>
      <dc:creator>scify</dc:creator>
      <dc:date>2014-07-15T15:59:06Z</dc:date>
    </item>
    <item>
      <title>Re: Incorrect macro logic</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Incorrect-macro-logic/m-p/180046#M34415</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;THIS &amp;lt;= &amp;amp;i &amp;lt;=&amp;nbsp; does not work as expected in macro language.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Change it to &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%if&amp;nbsp; 2000 &amp;lt;= &amp;amp;i&amp;nbsp; AND &amp;amp;i&amp;nbsp; &amp;lt;= 2011 or some variation thereof.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 15 Jul 2014 16:04:13 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Incorrect-macro-logic/m-p/180046#M34415</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2014-07-15T16:04:13Z</dc:date>
    </item>
  </channel>
</rss>

