<?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 Re: How to resolve Macro Variable as Part of Variable Name in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/How-to-resolve-Macro-Variable-as-Part-of-Variable-Name/m-p/9662#M562</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Probably this code is just a simplified version of what you are really doing, but it does not look like an application for a macro arithmetic.&amp;nbsp; &lt;/P&gt;&lt;P&gt;Seems it would be more appropriate to just write it in SAS rather then using the macro language to generate SAS code.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="plain" __jive_macro_name="code" class="jive_text_macro jive_macro_code"&gt;&lt;P&gt;data doudou;&lt;/P&gt;&lt;P&gt;&amp;nbsp; i=1;&lt;/P&gt;&lt;P&gt;&amp;nbsp; j=2;&lt;/P&gt;&lt;P&gt;&amp;nbsp; set mydata;&lt;/P&gt;&lt;P&gt;&amp;nbsp; array a a:;&lt;/P&gt;&lt;P&gt;&amp;nbsp; a((i-1)*18+(j-1)*6)=1;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Or perhaps you need a two dimension array?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="plain" __jive_macro_name="code" class="jive_text_macro jive_macro_code"&gt;&lt;P&gt;data doudou;&lt;/P&gt;&lt;P&gt;&amp;nbsp; i=1;&lt;/P&gt;&lt;P&gt;&amp;nbsp; j=2;&lt;/P&gt;&lt;P&gt;&amp;nbsp; set mydata;&lt;/P&gt;&lt;P&gt;&amp;nbsp; array a(18,6) a:;&lt;/P&gt;&lt;P&gt;&amp;nbsp; a(i,j)=1;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/PRE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Wed, 07 Dec 2011 00:25:10 GMT</pubDate>
    <dc:creator>Tom</dc:creator>
    <dc:date>2011-12-07T00:25:10Z</dc:date>
    <item>
      <title>How to resolve Macro Variable as Part of Variable Name</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-resolve-Macro-Variable-as-Part-of-Variable-Name/m-p/9659#M559</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi All,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I have a question regarding to the macro variable in a variable name.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P style="color: #222222; font-family: arial, sans-serif; text-align: -webkit-auto; background-color: rgba(255, 255, 255, 0.917969);"&gt;Basically, I want to decide an index which can be calculated from i and j, then I will use this index to create a variable name.&amp;nbsp; &lt;/P&gt;&lt;P style="color: #222222; font-family: arial, sans-serif; text-align: -webkit-auto; background-color: rgba(255, 255, 255, 0.917969);"&gt;For example, in the following code, I expect the dataset doudou to contain a variable a6=1 when i=1, j=2, but it didn't work. &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P style="color: #222222; font-family: arial, sans-serif; text-align: -webkit-auto; background-color: rgba(255, 255, 255, 0.917969);"&gt;Do you have any idea how to solve this question?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;DIV&gt;%let i=1;&lt;P&gt; %let j=2;&lt;/P&gt;&lt;P&gt;%let ind=(&amp;amp;i-1)*18+(&amp;amp;j-1)*6;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data doudou;&lt;/P&gt;&lt;P&gt;a&amp;amp;ind=1;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/DIV&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks for your attention!&lt;/P&gt;&lt;P&gt;xgn&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 06 Dec 2011 20:16:34 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-resolve-Macro-Variable-as-Part-of-Variable-Name/m-p/9659#M559</guid>
      <dc:creator>gxu</dc:creator>
      <dc:date>2011-12-06T20:16:34Z</dc:date>
    </item>
    <item>
      <title>How to resolve Macro Variable as Part of Variable Name</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-resolve-Macro-Variable-as-Part-of-Variable-Name/m-p/9660#M560</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt; &amp;amp;ind is a string&lt;/P&gt;&lt;P&gt;OK it contains an expression&lt;/P&gt;&lt;P&gt;when you want it evaluated, you need to do something&lt;/P&gt;&lt;P&gt;otherwise &lt;/P&gt;&lt;P&gt;a&amp;amp;ind is passed to the compiler as&lt;/P&gt;&lt;P&gt;a(&amp;amp;i-1)*18+(&amp;amp;j-1)*6&lt;/P&gt;&lt;P&gt;Then it has to decide if a( implies an array reference or a (probably user) function.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;If you wanted &lt;/P&gt;&lt;P&gt;a6&lt;/P&gt;&lt;P&gt;then you must encourage the evaluation of the expression in &amp;amp;ind&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Perhaps %eval( &amp;amp;ind ) might achieve what you want&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;as in&lt;/P&gt;&lt;P&gt;23&amp;nbsp;&amp;nbsp; %let i=1;&lt;BR /&gt;24&amp;nbsp;&amp;nbsp; %let j=2;&lt;BR /&gt;25&lt;BR /&gt;26&amp;nbsp;&amp;nbsp; %let ind=(&amp;amp;i-1)*18+(&amp;amp;j-1)*6;&lt;BR /&gt;27&lt;BR /&gt;28&amp;nbsp;&amp;nbsp; data doudou;&lt;BR /&gt;29&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; a%eval(&amp;amp;ind)=1;&lt;BR /&gt;30&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; putlog _all_ ;&lt;BR /&gt;31&amp;nbsp;&amp;nbsp; run ;&lt;/P&gt;&lt;P&gt;a6=1 _ERROR_=0 _N_=1&lt;BR /&gt;NOTE: The data set WORK.DOUDOU has&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;OK? &lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 06 Dec 2011 21:41:28 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-resolve-Macro-Variable-as-Part-of-Variable-Name/m-p/9660#M560</guid>
      <dc:creator>Peter_C</dc:creator>
      <dc:date>2011-12-06T21:41:28Z</dc:date>
    </item>
    <item>
      <title>How to resolve Macro Variable as Part of Variable Name</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-resolve-Macro-Variable-as-Part-of-Variable-Name/m-p/9661#M561</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Peter, &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Yes, it works, thank you!&amp;nbsp; P.S, I didn't know %eval before, it seems it's very useful for my future work&lt;img id="smileyhappy" class="emoticon emoticon-smileyhappy" src="https://communities.sas.com/i/smilies/16x16_smiley-happy.png" alt="Smiley Happy" title="Smiley Happy" /&gt;.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Best regards,&lt;/P&gt;&lt;P&gt;xgn&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 06 Dec 2011 22:33:07 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-resolve-Macro-Variable-as-Part-of-Variable-Name/m-p/9661#M561</guid>
      <dc:creator>gxu</dc:creator>
      <dc:date>2011-12-06T22:33:07Z</dc:date>
    </item>
    <item>
      <title>Re: How to resolve Macro Variable as Part of Variable Name</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-resolve-Macro-Variable-as-Part-of-Variable-Name/m-p/9662#M562</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Probably this code is just a simplified version of what you are really doing, but it does not look like an application for a macro arithmetic.&amp;nbsp; &lt;/P&gt;&lt;P&gt;Seems it would be more appropriate to just write it in SAS rather then using the macro language to generate SAS code.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="plain" __jive_macro_name="code" class="jive_text_macro jive_macro_code"&gt;&lt;P&gt;data doudou;&lt;/P&gt;&lt;P&gt;&amp;nbsp; i=1;&lt;/P&gt;&lt;P&gt;&amp;nbsp; j=2;&lt;/P&gt;&lt;P&gt;&amp;nbsp; set mydata;&lt;/P&gt;&lt;P&gt;&amp;nbsp; array a a:;&lt;/P&gt;&lt;P&gt;&amp;nbsp; a((i-1)*18+(j-1)*6)=1;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Or perhaps you need a two dimension array?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="plain" __jive_macro_name="code" class="jive_text_macro jive_macro_code"&gt;&lt;P&gt;data doudou;&lt;/P&gt;&lt;P&gt;&amp;nbsp; i=1;&lt;/P&gt;&lt;P&gt;&amp;nbsp; j=2;&lt;/P&gt;&lt;P&gt;&amp;nbsp; set mydata;&lt;/P&gt;&lt;P&gt;&amp;nbsp; array a(18,6) a:;&lt;/P&gt;&lt;P&gt;&amp;nbsp; a(i,j)=1;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/PRE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 07 Dec 2011 00:25:10 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-resolve-Macro-Variable-as-Part-of-Variable-Name/m-p/9662#M562</guid>
      <dc:creator>Tom</dc:creator>
      <dc:date>2011-12-07T00:25:10Z</dc:date>
    </item>
    <item>
      <title>Re: How to resolve Macro Variable as Part of Variable Name</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-resolve-Macro-Variable-as-Part-of-Variable-Name/m-p/9663#M563</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi Tom,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;You are right. The above code is just a simple version of what I am going to do.&amp;nbsp; I will also try your methods. Thank you so much!&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Best regards,&lt;/P&gt;&lt;P&gt;xgn&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 07 Dec 2011 14:49:31 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-resolve-Macro-Variable-as-Part-of-Variable-Name/m-p/9663#M563</guid>
      <dc:creator>gxu</dc:creator>
      <dc:date>2011-12-07T14:49:31Z</dc:date>
    </item>
  </channel>
</rss>

