<?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: Create Loop in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230186#M41730</link>
    <description>&lt;P&gt;If I understand correctly what you're after then the following should work.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
  infile datalines truncover dlm=',' dsd;
  input Id $ Date:ddmmyy10. Flag:$1.;
  format date ddmmyy10.;
  datalines;
1,31/01/2013,Y,
1,28/02/2013,Y,
1,31/03/2013,Y,
1,30/04/2013,
1,31/05/2013,
1,30/06/2013,
1,31/07/2013,
1,31/08/2013,
1,30/09/2013,Y,
1,31/10/2013,Y,
1,30/11/2013,Y,
1,31/12/2013,Y,
1,31/12/2014,Y,
1,30/11/2015,,
1,31/12/2015,Y,
2,31/01/2013,Y,
2,28/02/2013,Y,
2,31/03/2013,Y,
2,30/09/2013,Y,
2,31/10/2013,Y,
2,30/11/2013,Y,
2,31/12/2013,Y,
;
run;

proc sort data=have;
  by id date;
run;

data want1(drop=_:);
  set have curobs=curobs nobs=nobs;
  by id flag notsorted;
  format start_dt end_dt ddmmyy10.;

  _lag_date=lag(date);
  if flag='Y' then
    do;
      /* start_dt */
      if first.flag then start_dt=date;
      else if intnx('month',_lag_date,1,'e') ne date then start_dt=date; 

      /* end_dt */
      if last.flag  then end_dt=date;
      else if curobs&amp;lt;nobs then
        do;
          curobs+1;
          set have(keep=date rename=(date=_next_date))  point=curobs;
          if intnx('month',_next_date,-1,'e') ne date then end_dt=date;
        end;
    end;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;IMG src="https://communities.sas.com/t5/image/serverpage/image-id/514i3B54A9D030F3D012/image-size/original?v=mpbl-1&amp;amp;px=-1" border="0" alt="Capture.PNG" title="Capture.PNG" /&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Thu, 15 Oct 2015 22:22:02 GMT</pubDate>
    <dc:creator>Patrick</dc:creator>
    <dc:date>2015-10-15T22:22:02Z</dc:date>
    <item>
      <title>Create Loop</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230040#M41689</link>
      <description>&lt;P&gt;Hello Friends,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I am stuck on one problem and request for some help. Please see table below -&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;TABLE width="556"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="116"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;&lt;STRONG&gt;Id&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="116"&gt;&lt;STRONG&gt;Date&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="88"&gt;&lt;STRONG&gt;Flag&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="88"&gt;&lt;STRONG&gt;Start&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="64"&gt;&lt;STRONG&gt;End&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/01/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;28/02/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/03/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;30/04/2013&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/05/2013&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;30/06/2013&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/07/2013&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/08/2013&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;30/09/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/10/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;30/11/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/12/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;What I want to do is to create two new fields - Start_Date &amp;amp; End_Date which gets populated only when the Flag = "Y" something like the table below -&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;TABLE width="567"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="116"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="75"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;&lt;STRONG&gt;Id&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="116"&gt;&lt;STRONG&gt;Date&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="88"&gt;&lt;STRONG&gt;Flag&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="88"&gt;&lt;STRONG&gt;Start&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="75"&gt;&lt;STRONG&gt;End&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/01/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="88"&gt;31/01/2013&lt;/TD&gt;
&lt;TD width="75"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/03/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="75"&gt;31/03/2013&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;30/09/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="88"&gt;30/09/2013&lt;/TD&gt;
&lt;TD width="75"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="72"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/12/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="75"&gt;31/12/2013&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Any help will be geratly appreciated.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Regards&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Siddharth&lt;/P&gt;</description>
      <pubDate>Thu, 15 Oct 2015 09:58:24 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230040#M41689</guid>
      <dc:creator>Siddharth123</dc:creator>
      <dc:date>2015-10-15T09:58:24Z</dc:date>
    </item>
    <item>
      <title>Re: Create Loop</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230045#M41692</link>
      <description>&lt;P&gt;Assuming your source data is sorted by ID and Date something like below should work.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want1;
  set have;
  by id flag notsorted;
  format start_dt end_dt ddmmyy10.;
  if first.flag and flag='Y' then start_dt=date;
  if last.flag  and flag='Y' then end_dt=date;
run;

data want2;
  set have;
  by id flag notsorted;
  if first.flag and flag='Y' then start_end_ind='S';
  if last.flag  and flag='Y' then start_end_ind='E';
run;
&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Thu, 15 Oct 2015 10:19:10 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230045#M41692</guid>
      <dc:creator>Patrick</dc:creator>
      <dc:date>2015-10-15T10:19:10Z</dc:date>
    </item>
    <item>
      <title>Re: Create Loop</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230047#M41693</link>
      <description>&lt;P&gt;Thanks Patrick.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;This works but not perfectly!&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;The solution gives me 2 entries for Start &amp;amp; End date for the id. What I am trying is to have the values popualted for &lt;U&gt;&lt;EM&gt;&lt;STRONG&gt;"???"&lt;/STRONG&gt; &lt;/EM&gt;&lt;/U&gt;in table below. Soin final output, Id 1 should have 4 rows (but the solution you have will give me 2 rows!!) -&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;TABLE width="481"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;&lt;STRONG&gt;id&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="116"&gt;&lt;STRONG&gt;Date&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="88"&gt;&lt;STRONG&gt;Flag&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="75"&gt;&lt;STRONG&gt;start_dt&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="75"&gt;&lt;STRONG&gt;end_dt&lt;/STRONG&gt;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;30/04/2013&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/05/2013&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;30/06/2013&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/07/2013&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/08/2013&lt;/TD&gt;
&lt;TD width="88"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/01/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="75"&gt;31/01/2013&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;28/02/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/03/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;TD width="75"&gt;&lt;STRONG&gt;&lt;U&gt;???&lt;/U&gt;&lt;/STRONG&gt;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;30/09/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;TD width="75"&gt;&lt;STRONG&gt;&lt;U&gt;???&lt;/U&gt;&lt;/STRONG&gt;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/10/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;30/11/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="127"&gt;1&lt;/TD&gt;
&lt;TD width="116"&gt;31/12/2013&lt;/TD&gt;
&lt;TD width="88"&gt;Y&lt;/TD&gt;
&lt;TD width="75"&gt;.&lt;/TD&gt;
&lt;TD width="75"&gt;
&lt;P&gt;31/12/2013&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 15 Oct 2015 10:31:27 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230047#M41693</guid>
      <dc:creator>Siddharth123</dc:creator>
      <dc:date>2015-10-15T10:31:27Z</dc:date>
    </item>
    <item>
      <title>Re: Create Loop</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230048#M41694</link>
      <description>&lt;P&gt;Hi Patrick,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Sorry that I did not mention that the Start &amp;amp; End Dates get populated whenever there is a break in the actual "Date" column that is why we should have 4 entries for the Id 1.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Kind regards&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Siddharth&lt;/P&gt;</description>
      <pubDate>Thu, 15 Oct 2015 10:47:15 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230048#M41694</guid>
      <dc:creator>Siddharth123</dc:creator>
      <dc:date>2015-10-15T10:47:15Z</dc:date>
    </item>
    <item>
      <title>Re: Create Loop</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230109#M41712</link>
      <description>&lt;P&gt;Hi.&amp;nbsp; This gives four observations for ID=1.&amp;nbsp; I added an ID=2 set of data that starts with FLAG=Y and modified the data step that Patrick posted ...&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;data have;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;input id date :ddmmyy. flag :$1. @@;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;format date ddmmyy10.;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;datalines;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;1 31/01/2013 Y&amp;nbsp; 1 28/02/2013 Y&amp;nbsp; 1 31/03/2013 Y 1 30/04/2013 . &lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;1 31/05/2013 .&amp;nbsp; 1 30/06/2013 .&amp;nbsp; 1 31/07/2013 . 1 31/08/2013 . &lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;1 30/09/2013 Y&amp;nbsp; 1 31/10/2013 Y&amp;nbsp; 1 30/11/2013 Y 1 31/12/2013 Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;2 31/01/2013 Y&amp;nbsp; 2 28/02/2013 Y&amp;nbsp; 2 31/03/2013 Y 2 30/04/2013 . &lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;2 31/05/2013 Y&amp;nbsp; 2 30/06/2013 Y&amp;nbsp; 2 31/07/2013 . 2 31/08/2013 . &lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;2 30/09/2013 Y&amp;nbsp; 2 31/10/2013 .&amp;nbsp; 2 30/11/2013 Y 2 31/12/2013 Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;data want;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;format start_dt end_dt ddmmyy10.;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;set have;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;by id flag notsorted;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;if flag eq 'Y' then do;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp; if first.flag or first.id then start_dt=date;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp; if last.flag&amp;nbsp;then end_dt=date;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp; if first.flag or last.flag then output;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;end;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;run;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data set WANT (printed BY ID) ...&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;id=1&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;Obs&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; start_dt&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end_dt&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; date&amp;nbsp;&amp;nbsp;&amp;nbsp; flag&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp; 1&amp;nbsp;&amp;nbsp;&amp;nbsp; 31/01/2013&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; 31/01/2013&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp; 2&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; 31/03/2013&amp;nbsp;&amp;nbsp;&amp;nbsp; 31/03/2013&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp; 3&amp;nbsp;&amp;nbsp;&amp;nbsp; 30/09/2013&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; 30/09/2013&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp; 4&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; 31/12/2013&amp;nbsp;&amp;nbsp;&amp;nbsp; 31/12/2013&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;id=2&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;Obs&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; start_dt&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end_dt&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; date&amp;nbsp;&amp;nbsp;&amp;nbsp; flag&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp; 5&amp;nbsp;&amp;nbsp;&amp;nbsp; 31/01/2013&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; 31/01/2013&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp; 6&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; 31/03/2013&amp;nbsp;&amp;nbsp;&amp;nbsp; 31/03/2013&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp; 7&amp;nbsp;&amp;nbsp;&amp;nbsp; 31/05/2013&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; 31/05/2013&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp; 8&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; 30/06/2013&amp;nbsp;&amp;nbsp;&amp;nbsp; 30/06/2013&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp; 9&amp;nbsp;&amp;nbsp;&amp;nbsp; 30/09/2013&amp;nbsp;&amp;nbsp;&amp;nbsp; 30/09/2013&amp;nbsp;&amp;nbsp;&amp;nbsp; 30/09/2013&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;10&amp;nbsp;&amp;nbsp;&amp;nbsp; 30/11/2013&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; 30/11/2013&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;11&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; 31/12/2013&amp;nbsp;&amp;nbsp;&amp;nbsp; 31/12/2013&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Y&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 15 Oct 2015 15:38:06 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230109#M41712</guid>
      <dc:creator>MikeZdeb</dc:creator>
      <dc:date>2015-10-15T15:38:06Z</dc:date>
    </item>
    <item>
      <title>Re: Create Loop</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230186#M41730</link>
      <description>&lt;P&gt;If I understand correctly what you're after then the following should work.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
  infile datalines truncover dlm=',' dsd;
  input Id $ Date:ddmmyy10. Flag:$1.;
  format date ddmmyy10.;
  datalines;
1,31/01/2013,Y,
1,28/02/2013,Y,
1,31/03/2013,Y,
1,30/04/2013,
1,31/05/2013,
1,30/06/2013,
1,31/07/2013,
1,31/08/2013,
1,30/09/2013,Y,
1,31/10/2013,Y,
1,30/11/2013,Y,
1,31/12/2013,Y,
1,31/12/2014,Y,
1,30/11/2015,,
1,31/12/2015,Y,
2,31/01/2013,Y,
2,28/02/2013,Y,
2,31/03/2013,Y,
2,30/09/2013,Y,
2,31/10/2013,Y,
2,30/11/2013,Y,
2,31/12/2013,Y,
;
run;

proc sort data=have;
  by id date;
run;

data want1(drop=_:);
  set have curobs=curobs nobs=nobs;
  by id flag notsorted;
  format start_dt end_dt ddmmyy10.;

  _lag_date=lag(date);
  if flag='Y' then
    do;
      /* start_dt */
      if first.flag then start_dt=date;
      else if intnx('month',_lag_date,1,'e') ne date then start_dt=date; 

      /* end_dt */
      if last.flag  then end_dt=date;
      else if curobs&amp;lt;nobs then
        do;
          curobs+1;
          set have(keep=date rename=(date=_next_date))  point=curobs;
          if intnx('month',_next_date,-1,'e') ne date then end_dt=date;
        end;
    end;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;IMG src="https://communities.sas.com/t5/image/serverpage/image-id/514i3B54A9D030F3D012/image-size/original?v=mpbl-1&amp;amp;px=-1" border="0" alt="Capture.PNG" title="Capture.PNG" /&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 15 Oct 2015 22:22:02 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-Loop/m-p/230186#M41730</guid>
      <dc:creator>Patrick</dc:creator>
      <dc:date>2015-10-15T22:22:02Z</dc:date>
    </item>
  </channel>
</rss>

