<?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 Use do loop to output a single dataset into multiple ones in SAS Procedures</title>
    <link>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52953#M14587</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I've a dataset with start date and end date for distinct cases, and a missing end date indicates the peson is still alive. I just need to create multiple databases from 2005 to 2010 (as end of the observation year) to indicate if cases are alive/present in each respective year.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Here is the data I've.&lt;/P&gt;&lt;P&gt;data aa; input id startyear endyear;&lt;/P&gt;&lt;P&gt;datalines;&lt;/P&gt;&lt;P&gt;1 2005 2007&lt;/P&gt;&lt;P&gt;2 2006 2006&lt;/P&gt;&lt;P&gt;3 2007 &lt;/P&gt;&lt;P&gt;4 2008 2009&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Desired datasets with first column to indicate ID and second to indicate the person is present&lt;/P&gt;&lt;P&gt;data2005&lt;/P&gt;&lt;P&gt;1 1&lt;/P&gt;&lt;P&gt;data2006&lt;/P&gt;&lt;P&gt;1 1&lt;/P&gt;&lt;P&gt;2 1&lt;/P&gt;&lt;P&gt;data2007&lt;/P&gt;&lt;P&gt;1 1&lt;/P&gt;&lt;P&gt;4 1&lt;/P&gt;&lt;P&gt;data2008&lt;/P&gt;&lt;P&gt;3 1&lt;/P&gt;&lt;P&gt;4 1&lt;/P&gt;&lt;P&gt;data2009&lt;/P&gt;&lt;P&gt;3 1&lt;/P&gt;&lt;P&gt;4 1&lt;/P&gt;&lt;P&gt;data2010&lt;/P&gt;&lt;P&gt;3 1&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I know I should use macro and %do %to, and compare start/end year with the year in the %do year=2005 %to 2010. I tried a few variations but wasn't successful in producing my desired outcome. So thanks in advance for any help that can get me in the right track.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Tue, 14 Feb 2012 00:45:20 GMT</pubDate>
    <dc:creator>Solph</dc:creator>
    <dc:date>2012-02-14T00:45:20Z</dc:date>
    <item>
      <title>Use do loop to output a single dataset into multiple ones</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52953#M14587</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I've a dataset with start date and end date for distinct cases, and a missing end date indicates the peson is still alive. I just need to create multiple databases from 2005 to 2010 (as end of the observation year) to indicate if cases are alive/present in each respective year.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Here is the data I've.&lt;/P&gt;&lt;P&gt;data aa; input id startyear endyear;&lt;/P&gt;&lt;P&gt;datalines;&lt;/P&gt;&lt;P&gt;1 2005 2007&lt;/P&gt;&lt;P&gt;2 2006 2006&lt;/P&gt;&lt;P&gt;3 2007 &lt;/P&gt;&lt;P&gt;4 2008 2009&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Desired datasets with first column to indicate ID and second to indicate the person is present&lt;/P&gt;&lt;P&gt;data2005&lt;/P&gt;&lt;P&gt;1 1&lt;/P&gt;&lt;P&gt;data2006&lt;/P&gt;&lt;P&gt;1 1&lt;/P&gt;&lt;P&gt;2 1&lt;/P&gt;&lt;P&gt;data2007&lt;/P&gt;&lt;P&gt;1 1&lt;/P&gt;&lt;P&gt;4 1&lt;/P&gt;&lt;P&gt;data2008&lt;/P&gt;&lt;P&gt;3 1&lt;/P&gt;&lt;P&gt;4 1&lt;/P&gt;&lt;P&gt;data2009&lt;/P&gt;&lt;P&gt;3 1&lt;/P&gt;&lt;P&gt;4 1&lt;/P&gt;&lt;P&gt;data2010&lt;/P&gt;&lt;P&gt;3 1&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I know I should use macro and %do %to, and compare start/end year with the year in the %do year=2005 %to 2010. I tried a few variations but wasn't successful in producing my desired outcome. So thanks in advance for any help that can get me in the right track.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 14 Feb 2012 00:45:20 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52953#M14587</guid>
      <dc:creator>Solph</dc:creator>
      <dc:date>2012-02-14T00:45:20Z</dc:date>
    </item>
    <item>
      <title>Use do loop to output a single dataset into multiple ones</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52954#M14588</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Try this out:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data aa; &lt;/P&gt;&lt;P&gt;infile cards missover;&lt;/P&gt;&lt;P&gt;input id startyear endyear;&lt;/P&gt;&lt;P&gt;cards;&lt;/P&gt;&lt;P&gt;1 2005 2007&lt;/P&gt;&lt;P&gt;2 2006 2006&lt;/P&gt;&lt;P&gt;3 2007&lt;/P&gt;&lt;P&gt;4 2008 2009&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;%macro test;&lt;/P&gt;&lt;P&gt;%do year=2005 %to 2010;&lt;/P&gt;&lt;P&gt;data data&amp;amp;year(keep=id present );&lt;/P&gt;&lt;P&gt;set aa;&lt;/P&gt;&lt;P&gt;if startyear&amp;lt;= &amp;amp;year &amp;lt;= endyear or&amp;nbsp; (startyear&amp;lt;= &amp;amp;year and missing(endyear)) then&amp;nbsp; &lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; present=1;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; output;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;%end;&lt;/P&gt;&lt;P&gt;%mend;&lt;/P&gt;&lt;P&gt;%test&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;BTW, I believe you have a typo in your wanted data2007. It should be 3 1.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Regards,&lt;/P&gt;&lt;P&gt;Haikuo&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 14 Feb 2012 01:04:21 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52954#M14588</guid>
      <dc:creator>Haikuo</dc:creator>
      <dc:date>2012-02-14T01:04:21Z</dc:date>
    </item>
    <item>
      <title>Use do loop to output a single dataset into multiple ones</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52955#M14589</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Just for a fun.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE&gt;data aa;
infile cards missover;
input id startyear endyear;
cards;
1 2005 2007
2 2006 2006
3 2007
4 2008 2009
;
run;

data _null_;
present=1;
if 0 then set aa;
 declare hash ha(dataset:'aa',hashexp:10);
 declare hiter hi('ha');
&amp;nbsp; ha.definekey('id');
&amp;nbsp; ha.definedata('id','startyear','endyear');
&amp;nbsp; ha.definedone();
 declare hash h(hashexp:10);
&amp;nbsp; h.definekey('id');
&amp;nbsp; h.definedata('id','present');
&amp;nbsp; h.definedone(); 

do year=2005 to 2010;
 do while(hi.next()=0);
&amp;nbsp; if (year ge startyear and year le endyear) or (year ge startyear and missing(endyear))&amp;nbsp; then h.add();
 end;
 h.output(dataset: cats('data',year));&amp;nbsp; h.clear();
end;
run;
 

&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Tian.Kong&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 14 Feb 2012 03:55:18 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52955#M14589</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2012-02-14T03:55:18Z</dc:date>
    </item>
    <item>
      <title>Use do loop to output a single dataset into multiple ones</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52956#M14590</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Tian.Kong,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Your fun is hurting my brain right now :smileysilly:.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Haikuo&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 14 Feb 2012 04:02:42 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52956#M14590</guid>
      <dc:creator>Haikuo</dc:creator>
      <dc:date>2012-02-14T04:02:42Z</dc:date>
    </item>
    <item>
      <title>Use do loop to output a single dataset into multiple ones</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52957#M14591</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hai.Kuo&lt;/P&gt;&lt;P&gt;Take easy. Your code is more succinct and readable.&lt;/P&gt;&lt;P&gt;I think op like yours better than mine.&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;P&gt;&lt;/P&gt;&lt;P&gt;Ksharp&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;海阔天空&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 14 Feb 2012 04:28:42 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52957#M14591</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2012-02-14T04:28:42Z</dc:date>
    </item>
    <item>
      <title>Use do loop to output a single dataset into multiple ones</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52958#M14592</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Indeed yours is beyond my comprehension and my head was exploding just by reading it &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;. I tried Haikuo's and it worked the way I wanted. Thanks so much. You guys are always so great and helpful.&lt;/P&gt;&lt;P&gt;&lt;IMG id="smallDivTip" src="https://communities.sas.com/" style="z-index: 90; border: 0px solid blue; position: absolute; left: 474px; top: 7px;" /&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 14 Feb 2012 08:38:20 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Use-do-loop-to-output-a-single-dataset-into-multiple-ones/m-p/52958#M14592</guid>
      <dc:creator>Solph</dc:creator>
      <dc:date>2012-02-14T08:38:20Z</dc:date>
    </item>
  </channel>
</rss>

