<?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: Flag record when same event occurs within defined time period in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Flag-record-when-same-event-occurs-within-defined-time-period/m-p/328165#M271695</link>
    <description>&lt;P&gt;Worked perfectly!&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thank you so much!&lt;/P&gt;</description>
    <pubDate>Fri, 27 Jan 2017 22:35:06 GMT</pubDate>
    <dc:creator>SM1</dc:creator>
    <dc:date>2017-01-27T22:35:06Z</dc:date>
    <item>
      <title>Flag record when same event occurs within defined time period</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-record-when-same-event-occurs-within-defined-time-period/m-p/327897#M271692</link>
      <description>&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am working with personnel records that contain information about events (accession, promotion, retirement).&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I have the data both in long and wide (after transposing) format.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Accession events are codes 101 to 105&lt;/P&gt;&lt;P&gt;Promotion events are codes 400 to 600&lt;/P&gt;&lt;P&gt;Retirement events are codes 800 to 999&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;In the wide format, the data looks like this:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;ID &amp;nbsp; EventDate1 &amp;nbsp;EventCode1 &amp;nbsp;EventDate2 &amp;nbsp; EventCode2 &amp;nbsp;&lt;SPAN&gt;EventDate3 &amp;nbsp; &amp;nbsp;EventCode3 &amp;nbsp;EventDate4 &amp;nbsp; &amp;nbsp;EventCode4&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;1 &amp;nbsp; &amp;nbsp;05/01/1980 &amp;nbsp; 101 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;08/13/1985 &amp;nbsp; 501 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;03/17/1987 &amp;nbsp; &amp;nbsp;801 &amp;nbsp;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;2 &amp;nbsp; &amp;nbsp;10/26/1996 &amp;nbsp; 105 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;11/16/1996 &amp;nbsp; 105 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;01/18/2001 &amp;nbsp; &amp;nbsp;402 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;03/24/2008 &amp;nbsp; &amp;nbsp;801&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;3 &amp;nbsp; &amp;nbsp;11/04/1991 &amp;nbsp; 103 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;05/13/2004 &amp;nbsp; 575 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;09/24/2015 &amp;nbsp; &amp;nbsp;825 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;09/25/2015 &amp;nbsp; &amp;nbsp;826 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;&amp;nbsp;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;I need to flag a record where 2 consecutive events are the same type if the 2 events occur within 30 days of each other. So I would like to generate 3 new variables:&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;FlagA - flag for 2 accession events that happen within 30 days of each other&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;FlagP - flag for 2 promotion events that happen within 30 days of each other&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;FlagR - flag for 2 retirement events that happen within 30 days of each other&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;Output would look like this:&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;ID &amp;nbsp; EventDate1 &amp;nbsp;EventCode1 &amp;nbsp;EventDate2 &amp;nbsp; EventCode2 &amp;nbsp;&lt;SPAN&gt;EventDate3 &amp;nbsp; &amp;nbsp;EventCode3 &amp;nbsp;EventDate4 &amp;nbsp; &amp;nbsp;EventCode4 &amp;nbsp; FlagA &amp;nbsp;FlagP &amp;nbsp;FlagR&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;1 &amp;nbsp; &amp;nbsp;05/01/1980 &amp;nbsp; 101 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;08/13/1985 &amp;nbsp; 501 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;03/17/1987 &amp;nbsp; &amp;nbsp;801 &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;0 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 0 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 0&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;2 &amp;nbsp; &amp;nbsp;10/26/1996 &amp;nbsp; 105 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;11/16/1996 &amp;nbsp; 105 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;01/18/2001 &amp;nbsp; &amp;nbsp;402 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;03/24/2008 &amp;nbsp; &amp;nbsp;801 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;1 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 0 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 0&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;3 &amp;nbsp; &amp;nbsp;11/04/1991 &amp;nbsp; 103 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;05/13/2004 &amp;nbsp; 575 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;09/24/2015 &amp;nbsp; &amp;nbsp;825 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;09/25/2015 &amp;nbsp; &amp;nbsp;826 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;0 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 0 &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 1 &amp;nbsp;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;Any suggestions will be most appreciated.&lt;/SPAN&gt;&lt;/P&gt;</description>
      <pubDate>Thu, 26 Jan 2017 23:56:41 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-record-when-same-event-occurs-within-defined-time-period/m-p/327897#M271692</guid>
      <dc:creator>SM1</dc:creator>
      <dc:date>2017-01-26T23:56:41Z</dc:date>
    </item>
    <item>
      <title>Re: Flag record when same event occurs within defined time period</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-record-when-same-event-occurs-within-defined-time-period/m-p/327902#M271693</link>
      <description>&lt;P&gt;Can you assume any order in the variables? Do you know how many dates/codes you need to filter through in advance?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;You can use a DO loop, possibly a nested DO loop if you can't assume any order, in combination with two arrays for types and dates.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I would check for the&amp;nbsp;30 day interval first and then check if the events are the same.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Here's a code sketch - note this is untested and may have syntax errors, but should give you a good idea.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
set have;

array edates(*) eventdate1-eventdate4;
array ecodes(*) eventcode1-eventcode4;

flagA=0; flagP=0; flagR=0;

do i=1 to dim (edates)-1;

    if  0&amp;lt;=e_dates(i+1)-edates &amp;lt;=30 then do;

         if substrn(e_codes(i), 1,1) in (100:105) and substrn(e_codes(i+1),1,1) in (100:105) then flagA=1; 
end;
end;

run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 27 Jan 2017 00:52:48 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-record-when-same-event-occurs-within-defined-time-period/m-p/327902#M271693</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2017-01-27T00:52:48Z</dc:date>
    </item>
    <item>
      <title>Re: Flag record when same event occurs within defined time period</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-record-when-same-event-occurs-within-defined-time-period/m-p/327920#M271694</link>
      <description>&lt;P&gt;This is just an extension/completion of&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/13879"&gt;@Reeza&lt;/a&gt;'s code:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;data want;
  set have;
  array edates(*) eventdate:;
  array ecodes(*) eventcode:;
  flagA=0;
  flagP=0;
  flagR=0;
  do _n_=1 to dim (ecodes)-1;
    if substr(ecodes(_n_+1),1,1) eq substr(ecodes(_n_),1,1) and edates(_n_+1)-edates(_n_) le 30 then do;
      select;
        when (ecodes(_n_) in (100:105)) flagA=1;
        when (ecodes(_n_) in (400:600)) flagP=1;
        when (ecodes(_n_) in (800:999)) flagR=1;
        otherwise;
      end;
    end;
  end;
run;
;&lt;/PRE&gt;
&lt;P&gt;HTH,&lt;/P&gt;
&lt;P&gt;Art, CEO, AnalystFinder.com&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 27 Jan 2017 03:24:28 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-record-when-same-event-occurs-within-defined-time-period/m-p/327920#M271694</guid>
      <dc:creator>art297</dc:creator>
      <dc:date>2017-01-27T03:24:28Z</dc:date>
    </item>
    <item>
      <title>Re: Flag record when same event occurs within defined time period</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-record-when-same-event-occurs-within-defined-time-period/m-p/328165#M271695</link>
      <description>&lt;P&gt;Worked perfectly!&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thank you so much!&lt;/P&gt;</description>
      <pubDate>Fri, 27 Jan 2017 22:35:06 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-record-when-same-event-occurs-within-defined-time-period/m-p/328165#M271695</guid>
      <dc:creator>SM1</dc:creator>
      <dc:date>2017-01-27T22:35:06Z</dc:date>
    </item>
  </channel>
</rss>

