<?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: Using a MACRO variable in the INFILE statement in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Using-a-MACRO-variable-in-the-INFILE-statement/m-p/113559#M23402</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Without testing your code, I will guess that your problem is simply that periods are being treated as delimiter when you call the scan function. You can control what is, and isn't used as a delimiter, by specifying the modifier option.&amp;nbsp; Take a look at: &lt;/P&gt;&lt;P&gt;&lt;A href="http://support.sas.com/documentation/cdl/en/lrdict/64316/HTML/default/viewer.htm#a000214639.htm" title="http://support.sas.com/documentation/cdl/en/lrdict/64316/HTML/default/viewer.htm#a000214639.htm"&gt;SAS(R) 9.2 Language Reference: Dictionary, Fourth Edition&lt;/A&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Tue, 15 Oct 2013 22:32:57 GMT</pubDate>
    <dc:creator>art297</dc:creator>
    <dc:date>2013-10-15T22:32:57Z</dc:date>
    <item>
      <title>Using a MACRO variable in the INFILE statement</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-a-MACRO-variable-in-the-INFILE-statement/m-p/113558#M23401</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello. Would you please help me? I'm a beginner in the world of macro.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I have downloaded about 300 raw data files, monthly data between 1989 and 2013. I need only about 10 variables in each file. I have the list of the physical names of all the raw data files. Then, I have to create a new data file for each month. For example,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;RAW DATA&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;&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; NEW DATA&lt;/P&gt;&lt;P&gt;c:\cps\cpsb91\cpsb9111&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; --&amp;gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; c:\cps\replicate\d199111.sas7bdat&lt;/P&gt;&lt;P&gt;c:\cps\cpsb91\cpsb9112&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; --&amp;gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; c:\cps\replicate\d199112.sas7bdat&lt;/P&gt;&lt;P&gt;c:\cps\cpsb92\cpsb9201&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; --&amp;gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; c:\cps\replicate\d199201.sas7bdat&lt;/P&gt;&lt;P&gt;c:\cps\cpsb92\cpsb9202&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; --&amp;gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; c:\cps\replicate\d199202.sas7bdat&lt;/P&gt;&lt;P&gt;c:\cps\cpsb92\cpsb9203&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; --&amp;gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; c:\cps\replicate\d199203.sas7bdat&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-size: 10pt; line-height: 1.5em;"&gt;. . . and so forth&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;So, I thought I had to use MACRO. The problem that I cannot solve is that the program below works beautifully only if the raw data file has no extension, such as ".dat"&lt;/P&gt;&lt;P&gt;______________________________________________________________________&lt;/P&gt;&lt;P&gt;libname replicat 'c:\cps\replicate';&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%macro CPSMACRO/parmbuff;&lt;/P&gt;&lt;P&gt;%let i=1;&lt;/P&gt;&lt;P&gt;%let m=6;&lt;/P&gt;&lt;P&gt;%let y=1995;&lt;/P&gt;&lt;P&gt;%let prfx=d;&lt;/P&gt;&lt;P&gt;%let raw=%scan(&amp;amp;syspbuff,&amp;amp;i);&lt;/P&gt;&lt;P&gt;%do %while(&amp;amp;raw ne);&lt;/P&gt;&lt;P&gt;%let yyyymm=%eval(&amp;amp;y*100+&amp;amp;m);&lt;/P&gt;&lt;P&gt;%let fname=&amp;amp;prfx.&amp;amp;yyyymm;&lt;/P&gt;&lt;P&gt;data replicat.&amp;amp;fname.;&lt;/P&gt;&lt;P&gt;infile &amp;amp;raw. lrecl=2300 missover;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;lt;-- In this INFILE statement, I include the macro variable.&lt;/P&gt;&lt;P&gt;input&lt;/P&gt;&lt;P&gt;@1 hh 15.&lt;/P&gt;&lt;P&gt;@122 age 2.&lt;/P&gt;&lt;P&gt;@436 ind $3.&lt;/P&gt;&lt;P&gt;@439 occu $3.&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;%if &amp;amp;m=12 %then %do;&lt;/P&gt;&lt;P&gt;&amp;nbsp; %let i=%eval(&amp;amp;i+1);&lt;/P&gt;&lt;P&gt;&amp;nbsp; %let m=1;&lt;/P&gt;&lt;P&gt;&amp;nbsp; %let y=%eval(&amp;amp;y+1);&lt;/P&gt;&lt;P&gt;&amp;nbsp; %let raw=%scan(&amp;amp;syspbuff,&amp;amp;i);&lt;/P&gt;&lt;P&gt;%end;&lt;/P&gt;&lt;P&gt;%else %do;&lt;/P&gt;&lt;P&gt;&amp;nbsp; %let i=%eval(&amp;amp;i+1);&lt;/P&gt;&lt;P&gt;&amp;nbsp; %let m=%eval(&amp;amp;m+1);&lt;/P&gt;&lt;P&gt;&amp;nbsp; %let raw=%scan(&amp;amp;syspbuff,&amp;amp;i);&lt;/P&gt;&lt;P&gt;%end;&lt;/P&gt;&lt;P&gt;%end;&lt;/P&gt;&lt;P&gt;%mend CPSMACRO;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%CPSMACRO(&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;&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;lt;-- I run the macro and input the physical name of three raw data files, for example.&lt;/P&gt;&lt;P&gt;'C:\cps\cpsb95\cpsb9506'&lt;/P&gt;&lt;P&gt;'C:\cps\cpsb95\cpsb9507'&lt;/P&gt;&lt;P&gt;'C:\cps\cpsb95\cpsaug95.dat');&lt;/P&gt;&lt;P&gt;______________________________________________________________________&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;This macro works only for the first two data files, and yields an error message (ERROR: Literal contains unmatched quote) for the third one.&lt;/P&gt;&lt;P&gt;I've tried both single-quote and double-quote, but neither works. Would you please help me? Thank you so very much.&lt;/P&gt;&lt;P&gt;Rakkoo&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 15 Oct 2013 22:22:48 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-a-MACRO-variable-in-the-INFILE-statement/m-p/113558#M23401</guid>
      <dc:creator>Rakkoo</dc:creator>
      <dc:date>2013-10-15T22:22:48Z</dc:date>
    </item>
    <item>
      <title>Re: Using a MACRO variable in the INFILE statement</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-a-MACRO-variable-in-the-INFILE-statement/m-p/113559#M23402</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Without testing your code, I will guess that your problem is simply that periods are being treated as delimiter when you call the scan function. You can control what is, and isn't used as a delimiter, by specifying the modifier option.&amp;nbsp; Take a look at: &lt;/P&gt;&lt;P&gt;&lt;A href="http://support.sas.com/documentation/cdl/en/lrdict/64316/HTML/default/viewer.htm#a000214639.htm" title="http://support.sas.com/documentation/cdl/en/lrdict/64316/HTML/default/viewer.htm#a000214639.htm"&gt;SAS(R) 9.2 Language Reference: Dictionary, Fourth Edition&lt;/A&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 15 Oct 2013 22:32:57 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-a-MACRO-variable-in-the-INFILE-statement/m-p/113559#M23402</guid>
      <dc:creator>art297</dc:creator>
      <dc:date>2013-10-15T22:32:57Z</dc:date>
    </item>
    <item>
      <title>Re: Using a MACRO variable in the INFILE statement</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-a-MACRO-variable-in-the-INFILE-statement/m-p/113560#M23403</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Excellent! It was the delimiter! Now the macro works. Thanks a lot!&amp;nbsp; &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;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 15 Oct 2013 23:33:12 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-a-MACRO-variable-in-the-INFILE-statement/m-p/113560#M23403</guid>
      <dc:creator>Rakkoo</dc:creator>
      <dc:date>2013-10-15T23:33:12Z</dc:date>
    </item>
  </channel>
</rss>

