<?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: Do Loop for each ID variable/Conditional statements in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94720#M257652</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;borrowed DN's data. the code bellow is inefficient, but it is easy to understand:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data odd;&lt;BR /&gt;&amp;nbsp;&amp;nbsp; input id $ status amount month;&lt;BR /&gt;&amp;nbsp;&amp;nbsp; cards; &lt;BR /&gt;125 1 1200 1&lt;BR /&gt;125 2 1300 2&lt;BR /&gt;125 1 1300 3&lt;BR /&gt;125 2 1300 4&lt;BR /&gt;127 0 1234 1&lt;BR /&gt;127 2 1000 2&lt;BR /&gt;127 2 1001 3&lt;BR /&gt;127 0&amp;nbsp; 999 4&lt;BR /&gt;130 0 1212 5&lt;BR /&gt;130 0 1200 6&lt;BR /&gt;;;;;&lt;BR /&gt;data temp1(keep=id amount);&lt;BR /&gt;&amp;nbsp; set odd;&lt;BR /&gt;&amp;nbsp; by id notsorted;&lt;BR /&gt;&amp;nbsp; if first.id;&lt;BR /&gt;run;&lt;BR /&gt;proc sort data=odd out=temp2;&lt;BR /&gt; by id descending status month;&lt;BR /&gt;data temp3(drop=amount);&lt;BR /&gt;&amp;nbsp; set temp2;&lt;BR /&gt;&amp;nbsp; by id;&lt;BR /&gt;&amp;nbsp; if first.id;&lt;BR /&gt; run;&lt;BR /&gt; data want;&lt;BR /&gt; merge temp1 temp3;&lt;BR /&gt; by id;&lt;BR /&gt;proc print;run;&lt;/P&gt;&lt;P&gt;Obs&amp;nbsp;&amp;nbsp;&amp;nbsp; id&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; amount&amp;nbsp;&amp;nbsp;&amp;nbsp; status&amp;nbsp;&amp;nbsp;&amp;nbsp; month&lt;/P&gt;&lt;P&gt; 1&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 125&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 1200&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; 2&lt;BR /&gt; 2&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 127&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 1234&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; 2&lt;BR /&gt; 3&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 130&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 1212&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 5&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Mon, 10 Dec 2012 20:45:11 GMT</pubDate>
    <dc:creator>Linlin</dc:creator>
    <dc:date>2012-12-10T20:45:11Z</dc:date>
    <item>
      <title>Do Loop for each ID variable/Conditional statements</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94716#M257648</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I have a data set of the following type:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;IMG __jive_id="2806" alt="" class="jiveImage" src="https://communities.sas.com/legacyfs/online/2806_pastedImage_2.png" style="width: 346px; height: 233px;" /&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I want to have&amp;nbsp; a single row per ID in such a way that&amp;nbsp; it picks the maximum value of the status at its first occurrence and the month corresponding to the row that has max value of status.&lt;/P&gt;&lt;P&gt;The values of the remaining variables should be picked from row 1.&lt;/P&gt;&lt;P&gt;The new data set should look like&lt;/P&gt;&lt;P&gt;ID&amp;nbsp;&amp;nbsp; Status&amp;nbsp; Amount&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Month&lt;/P&gt;&lt;P&gt;125&amp;nbsp;&amp;nbsp;&amp;nbsp; 2&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 1200&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 2&lt;/P&gt;&lt;P&gt;127&amp;nbsp;&amp;nbsp;&amp;nbsp; 2&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 1234&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 2&lt;/P&gt;&lt;P&gt;130&amp;nbsp;&amp;nbsp;&amp;nbsp; 0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 212&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 5&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks!&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sun, 09 Dec 2012 20:11:22 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94716#M257648</guid>
      <dc:creator>rnmishra</dc:creator>
      <dc:date>2012-12-09T20:11:22Z</dc:date>
    </item>
    <item>
      <title>Re: Do Loop for each ID variable/Conditional statements</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94717#M257649</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;A datastep works well in this scenario. &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data want;&lt;/P&gt;&lt;P&gt;set have;&lt;/P&gt;&lt;P&gt;by id;&lt;/P&gt;&lt;P&gt;retain new_status;&lt;/P&gt;&lt;P&gt;if first.id then do;&lt;/P&gt;&lt;P&gt;new_amount=amount;&lt;/P&gt;&lt;P&gt;new_status=status;&lt;/P&gt;&lt;P&gt;new_month=month;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;end;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;if status &amp;gt; new_status then do;&lt;/P&gt;&lt;P&gt;new_status=status;&lt;/P&gt;&lt;P&gt;new_month=month;&lt;/P&gt;&lt;P&gt;end;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;if last.id then output;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;drop status account month;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 10 Dec 2012 03:50:30 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94717#M257649</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2012-12-10T03:50:30Z</dc:date>
    </item>
    <item>
      <title>Re: Do Loop for each ID variable/Conditional statements</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94718#M257650</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Here is a SQL approach:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Proc sql;&lt;/P&gt;&lt;P&gt;create table want as&lt;/P&gt;&lt;P&gt; select * from&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; (select * from have group by id having status=max(status))&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; group by id, status having month=min(month)&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Haikuo&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 10 Dec 2012 04:59:23 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94718#M257650</guid>
      <dc:creator>Haikuo</dc:creator>
      <dc:date>2012-12-10T04:59:23Z</dc:date>
    </item>
    <item>
      <title>Re: Do Loop for each ID variable/Conditional statements</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94719#M257651</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;PROC MEAN/SUMMARY has features that are specifically designed for this problem.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;DIV style="font-family: Courier New; font-size: 11pt;"&gt;&lt;STRONG style="color: #000080; background-color: #ffffff;"&gt;data&lt;/STRONG&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt; odd;&lt;BR /&gt;&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;&amp;nbsp;&amp;nbsp; &lt;/SPAN&gt;&lt;SPAN style="color: #0000ff; background-color: #ffffff;"&gt;input&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt; id $ status amount month;&lt;BR /&gt;&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;&amp;nbsp;&amp;nbsp; &lt;/SPAN&gt;&lt;SPAN style="color: #0000ff; background-color: #ffffff;"&gt;cards&lt;/SPAN&gt;; &lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;&lt;BR /&gt;&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffc0;"&gt;125 1 1200 1&lt;BR /&gt;125 2 1300 2&lt;BR /&gt;125 1 1300 3&lt;BR /&gt;125 2 1300 4&lt;BR /&gt;&lt;BR /&gt;127 0 1234 1&lt;BR /&gt;127 2 1000 2&lt;BR /&gt;127 2 1001 3&lt;BR /&gt;127 0&amp;nbsp; 999 4&lt;BR /&gt;&lt;BR /&gt;130 0 1212 5&lt;BR /&gt;130 0 1200 6&lt;BR /&gt;&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;;;;;&lt;BR /&gt;&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;&amp;nbsp;&amp;nbsp; &lt;/SPAN&gt;&lt;STRONG style="color: #000080; background-color: #ffffff;"&gt;run&lt;/STRONG&gt;; &lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;&lt;BR /&gt;&lt;/SPAN&gt;&lt;STRONG style="color: #000080; background-color: #ffffff;"&gt;proc&lt;/STRONG&gt; &lt;STRONG style="color: #000080; background-color: #ffffff;"&gt;summary&lt;/STRONG&gt; &lt;SPAN style="color: #0000ff; background-color: #ffffff;"&gt;nway&lt;/SPAN&gt;; &lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;&lt;BR /&gt;&amp;nbsp;&amp;nbsp; &lt;/SPAN&gt;&lt;SPAN style="color: #0000ff; background-color: #ffffff;"&gt;class&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt; id;&lt;BR /&gt;&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;&amp;nbsp;&amp;nbsp; &lt;/SPAN&gt;&lt;SPAN style="color: #0000ff; background-color: #ffffff;"&gt;output&lt;/SPAN&gt; &lt;SPAN style="color: #0000ff; background-color: #ffffff;"&gt;out&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;=oddsubset&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/SPAN&gt;&lt;SPAN style="color: #0000ff; background-color: #ffffff;"&gt;idgroup&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;(&lt;/SPAN&gt;&lt;SPAN style="color: #0000ff; background-color: #ffffff;"&gt;max&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;(status) &lt;/SPAN&gt;&lt;SPAN style="color: #0000ff; background-color: #ffffff;"&gt;out&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;(status month)=)&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/SPAN&gt;&lt;SPAN style="color: #0000ff; background-color: #ffffff;"&gt;idgroup&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;(&lt;/SPAN&gt;&lt;SPAN style="color: #0000ff; background-color: #ffffff;"&gt;out&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;(amount)=)&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ;&lt;BR /&gt;&lt;/SPAN&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;&amp;nbsp;&amp;nbsp; &lt;/SPAN&gt;&lt;STRONG style="color: #000080; background-color: #ffffff;"&gt;run&lt;/STRONG&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;;&lt;/SPAN&gt;&lt;/DIV&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 10 Dec 2012 14:20:45 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94719#M257651</guid>
      <dc:creator>data_null__</dc:creator>
      <dc:date>2012-12-10T14:20:45Z</dc:date>
    </item>
    <item>
      <title>Re: Do Loop for each ID variable/Conditional statements</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94720#M257652</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;borrowed DN's data. the code bellow is inefficient, but it is easy to understand:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data odd;&lt;BR /&gt;&amp;nbsp;&amp;nbsp; input id $ status amount month;&lt;BR /&gt;&amp;nbsp;&amp;nbsp; cards; &lt;BR /&gt;125 1 1200 1&lt;BR /&gt;125 2 1300 2&lt;BR /&gt;125 1 1300 3&lt;BR /&gt;125 2 1300 4&lt;BR /&gt;127 0 1234 1&lt;BR /&gt;127 2 1000 2&lt;BR /&gt;127 2 1001 3&lt;BR /&gt;127 0&amp;nbsp; 999 4&lt;BR /&gt;130 0 1212 5&lt;BR /&gt;130 0 1200 6&lt;BR /&gt;;;;;&lt;BR /&gt;data temp1(keep=id amount);&lt;BR /&gt;&amp;nbsp; set odd;&lt;BR /&gt;&amp;nbsp; by id notsorted;&lt;BR /&gt;&amp;nbsp; if first.id;&lt;BR /&gt;run;&lt;BR /&gt;proc sort data=odd out=temp2;&lt;BR /&gt; by id descending status month;&lt;BR /&gt;data temp3(drop=amount);&lt;BR /&gt;&amp;nbsp; set temp2;&lt;BR /&gt;&amp;nbsp; by id;&lt;BR /&gt;&amp;nbsp; if first.id;&lt;BR /&gt; run;&lt;BR /&gt; data want;&lt;BR /&gt; merge temp1 temp3;&lt;BR /&gt; by id;&lt;BR /&gt;proc print;run;&lt;/P&gt;&lt;P&gt;Obs&amp;nbsp;&amp;nbsp;&amp;nbsp; id&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; amount&amp;nbsp;&amp;nbsp;&amp;nbsp; status&amp;nbsp;&amp;nbsp;&amp;nbsp; month&lt;/P&gt;&lt;P&gt; 1&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 125&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 1200&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; 2&lt;BR /&gt; 2&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 127&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 1234&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; 2&lt;BR /&gt; 3&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 130&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 1212&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 5&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 10 Dec 2012 20:45:11 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94720#M257652</guid>
      <dc:creator>Linlin</dc:creator>
      <dc:date>2012-12-10T20:45:11Z</dc:date>
    </item>
    <item>
      <title>Re: Do Loop for each ID variable/Conditional statements</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94721#M257653</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Thanks!&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 11 Dec 2012 07:26:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Do-Loop-for-each-ID-variable-Conditional-statements/m-p/94721#M257653</guid>
      <dc:creator>rnmishra</dc:creator>
      <dc:date>2012-12-11T07:26:19Z</dc:date>
    </item>
  </channel>
</rss>

