<?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: Programming in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Programming/m-p/704581#M216004</link>
    <description>&lt;P&gt;First requirement: Have the dates as numeric values, and best a SAS format that displays them as a usable date. Note: a number like 20201102 is not a SAS date.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;data want; 
   set have;
   by patient;&lt;BR /&gt;   lend = lag(end_date);
   if not first.patient then daysdiff = Start_date - Lend;&lt;BR /&gt;   drop lend;
run;&lt;/PRE&gt;
&lt;P&gt;The LAG function maintains a queue of prior values so you can access them.&lt;/P&gt;
&lt;P&gt;When using BY group in a data set SAS creates automatic variables First. and Last. for each variable on the By statement that you can test for true/false.&lt;/P&gt;</description>
    <pubDate>Tue, 08 Dec 2020 22:50:06 GMT</pubDate>
    <dc:creator>ballardw</dc:creator>
    <dc:date>2020-12-08T22:50:06Z</dc:date>
    <item>
      <title>Programming</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Programming/m-p/704573#M216002</link>
      <description>&lt;P&gt;I have 2 dates (start date&amp;nbsp; end date) for an encounter by patient. I have multiple encounters. How do I subtract the last date of one encounter from the first date of the next encounter for each patient?&lt;/P&gt;&lt;P&gt;HAVE DATASET&amp;nbsp;&lt;/P&gt;&lt;P&gt;PATIENT&amp;nbsp; ENCOUNTER START DATE&amp;nbsp; &amp;nbsp; &amp;nbsp;END DATE&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;1&amp;nbsp; &amp;nbsp; &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; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;ST_DATE_1&amp;nbsp; &amp;nbsp; &amp;nbsp; END_DATE_1&lt;/P&gt;&lt;P&gt;1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;&amp;nbsp;ST_DATE_2&amp;nbsp; &amp;nbsp;END_DATE_2&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 3&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;&amp;nbsp;ST_DATE_3&amp;nbsp; &amp;nbsp; &amp;nbsp; END_DATE_3&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 4&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;&amp;nbsp;ST_DATE_4&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;END_DATE_4&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;WANT DATASET&lt;/P&gt;&lt;P&gt;PATIENT&amp;nbsp; ENCOUNTER&amp;nbsp; &amp;nbsp; DIFF_END DATE_START DATE_FOR CONSECUTIVE RECORDS&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;&lt;/P&gt;&lt;P&gt;1&amp;nbsp; &amp;nbsp; &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; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; .&lt;/P&gt;&lt;P&gt;1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;DIFF START_DATE_2 &amp;amp;&amp;nbsp;END_DATE_1&lt;/P&gt;&lt;P&gt;1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 3&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;DIFF START_DATE_3 &amp;amp;&amp;nbsp;END_DATE_2&lt;/P&gt;&lt;P&gt;1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 4&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;DIFF START_DATE_4 &amp;amp;&amp;nbsp;END_DATE_3&lt;/P&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>Tue, 08 Dec 2020 22:31:27 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Programming/m-p/704573#M216002</guid>
      <dc:creator>Deep_Impact</dc:creator>
      <dc:date>2020-12-08T22:31:27Z</dc:date>
    </item>
    <item>
      <title>Re: Programming</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Programming/m-p/704581#M216004</link>
      <description>&lt;P&gt;First requirement: Have the dates as numeric values, and best a SAS format that displays them as a usable date. Note: a number like 20201102 is not a SAS date.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;data want; 
   set have;
   by patient;&lt;BR /&gt;   lend = lag(end_date);
   if not first.patient then daysdiff = Start_date - Lend;&lt;BR /&gt;   drop lend;
run;&lt;/PRE&gt;
&lt;P&gt;The LAG function maintains a queue of prior values so you can access them.&lt;/P&gt;
&lt;P&gt;When using BY group in a data set SAS creates automatic variables First. and Last. for each variable on the By statement that you can test for true/false.&lt;/P&gt;</description>
      <pubDate>Tue, 08 Dec 2020 22:50:06 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Programming/m-p/704581#M216004</guid>
      <dc:creator>ballardw</dc:creator>
      <dc:date>2020-12-08T22:50:06Z</dc:date>
    </item>
    <item>
      <title>Re: Programming</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Programming/m-p/704926#M216141</link>
      <description>Hi ballardw,&lt;BR /&gt;&lt;BR /&gt;Thank you for your prompt reply. It did work and got what I wanted. Only thing in the program log was that first.patient is uninitialized.</description>
      <pubDate>Thu, 10 Dec 2020 04:31:51 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Programming/m-p/704926#M216141</guid>
      <dc:creator>Deep_Impact</dc:creator>
      <dc:date>2020-12-10T04:31:51Z</dc:date>
    </item>
  </channel>
</rss>

