<?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 Create a macro variable for each unique value of a variable. in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Create-a-macro-variable-for-each-unique-value-of-a-variable/m-p/110065#M258858</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;The values of a variable -var1 of my data set&amp;nbsp; changes every month.&lt;/P&gt;&lt;P&gt;I am interested to create a macro variable for each unique value of the variable -Var1.....This time I have 5 different (unique) values of Var1. The macro variable &amp;amp;NumUni counts the number of unique values of Var1.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Here is my attempt!&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The data set have contains a row for each unique value of Var1.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%MACRO LOOP;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %DO I=1 %TO %sysevalf(&amp;amp;NumUni);&lt;BR /&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; DATA _NULL_;&lt;BR /&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; SET Have;&lt;BR /&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 _N_=&amp;amp;I&amp;nbsp; THEN CALL SYMPUTX('X&amp;amp;I',Var1);&lt;BR /&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; RUN;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %END;&lt;BR /&gt;%MEND LOOP;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;In this case NumUni=5, so I should be creating 5 macro variables X1, X2,X3,X4 and X5.&lt;/P&gt;&lt;P&gt;There is some thing wrong with SYMPUTX('X&amp;amp;I',Var1);&lt;/P&gt;&lt;P&gt;Any help would be highly appreciated!&lt;/P&gt;&lt;P&gt;Thanks!&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Fri, 28 Dec 2012 18:58:55 GMT</pubDate>
    <dc:creator>rnmishra</dc:creator>
    <dc:date>2012-12-28T18:58:55Z</dc:date>
    <item>
      <title>Create a macro variable for each unique value of a variable.</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-a-macro-variable-for-each-unique-value-of-a-variable/m-p/110065#M258858</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;The values of a variable -var1 of my data set&amp;nbsp; changes every month.&lt;/P&gt;&lt;P&gt;I am interested to create a macro variable for each unique value of the variable -Var1.....This time I have 5 different (unique) values of Var1. The macro variable &amp;amp;NumUni counts the number of unique values of Var1.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Here is my attempt!&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The data set have contains a row for each unique value of Var1.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%MACRO LOOP;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %DO I=1 %TO %sysevalf(&amp;amp;NumUni);&lt;BR /&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; DATA _NULL_;&lt;BR /&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; SET Have;&lt;BR /&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 _N_=&amp;amp;I&amp;nbsp; THEN CALL SYMPUTX('X&amp;amp;I',Var1);&lt;BR /&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; RUN;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; %END;&lt;BR /&gt;%MEND LOOP;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;In this case NumUni=5, so I should be creating 5 macro variables X1, X2,X3,X4 and X5.&lt;/P&gt;&lt;P&gt;There is some thing wrong with SYMPUTX('X&amp;amp;I',Var1);&lt;/P&gt;&lt;P&gt;Any help would be highly appreciated!&lt;/P&gt;&lt;P&gt;Thanks!&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 28 Dec 2012 18:58:55 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-a-macro-variable-for-each-unique-value-of-a-variable/m-p/110065#M258858</guid>
      <dc:creator>rnmishra</dc:creator>
      <dc:date>2012-12-28T18:58:55Z</dc:date>
    </item>
    <item>
      <title>Re: Create a macro variable for each unique value of a variable.</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-a-macro-variable-for-each-unique-value-of-a-variable/m-p/110066#M258859</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi,&lt;/P&gt;&lt;P&gt;Try this..you can also use count(name) into a macro variable.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%let NumUni=10;&lt;/P&gt;&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;select distinct name into :var1-:var&amp;amp;NumUni from sashelp.class;&lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;Shiva&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 28 Dec 2012 19:41:11 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-a-macro-variable-for-each-unique-value-of-a-variable/m-p/110066#M258859</guid>
      <dc:creator>shivas</dc:creator>
      <dc:date>2012-12-28T19:41:11Z</dc:date>
    </item>
    <item>
      <title>Re: Create a macro variable for each unique value of a variable.</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-a-macro-variable-for-each-unique-value-of-a-variable/m-p/110067#M258860</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Thanks.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 28 Dec 2012 19:47:15 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-a-macro-variable-for-each-unique-value-of-a-variable/m-p/110067#M258860</guid>
      <dc:creator>rnmishra</dc:creator>
      <dc:date>2012-12-28T19:47:15Z</dc:date>
    </item>
    <item>
      <title>Re: Create a macro variable for each unique value of a variable.</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-a-macro-variable-for-each-unique-value-of-a-variable/m-p/110068#M258861</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Your code seems correct, except macro variables only resolve inside double quotes not single quotes.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;You also don't need macro code, here's a datastep solution that assumes you have a sorted dataset and there are variations to handle unsorted data but you don't have to know the number of records ahead of time.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data _null_;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; set sashelp.class;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; by name;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; count=0;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; if first.name then count+1;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; call symput("x"||compress(count), name);&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%put &amp;amp;x1;&lt;/P&gt;&lt;P&gt;%put &amp;amp;x12;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 28 Dec 2012 20:17:43 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-a-macro-variable-for-each-unique-value-of-a-variable/m-p/110068#M258861</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2012-12-28T20:17:43Z</dc:date>
    </item>
    <item>
      <title>Re: Create a macro variable for each unique value of a variable.</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-a-macro-variable-for-each-unique-value-of-a-variable/m-p/110069#M258862</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Thanks all of you for your help.&lt;/P&gt;&lt;P&gt;For any&amp;nbsp; beginner like this one, the following material provides some extra tips.&lt;/P&gt;&lt;P&gt;&lt;A href="http://support.sas.com/documentation/cdl/en/sqlproc/63043/HTML/default/viewer.htm#p0lsf4btafkw9mn1md4c69kkfwbl.htm" title="http://support.sas.com/documentation/cdl/en/sqlproc/63043/HTML/default/viewer.htm#p0lsf4btafkw9mn1md4c69kkfwbl.htm"&gt;SAS(R) 9.3 SQL Procedure User's Guide&lt;/A&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 29 Dec 2012 17:22:00 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-a-macro-variable-for-each-unique-value-of-a-variable/m-p/110069#M258862</guid>
      <dc:creator>rnmishra</dc:creator>
      <dc:date>2012-12-29T17:22:00Z</dc:date>
    </item>
  </channel>
</rss>

