<?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: For Each Update Loop? in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389668#M93440</link>
    <description>&lt;P&gt;data class2; set sashelp.class;&lt;BR /&gt;if weight &amp;gt; 100 then age = .;&lt;BR /&gt;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;proc sort data=class2;&lt;BR /&gt;by sex descending age ;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;data class2; set class2;&lt;BR /&gt;if age = 12 then age = .;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;For both genders, I am trying to fill the age with the age before it if it is blank.&lt;/P&gt;</description>
    <pubDate>Mon, 21 Aug 2017 21:00:08 GMT</pubDate>
    <dc:creator>DavidPhillips2</dc:creator>
    <dc:date>2017-08-21T21:00:08Z</dc:date>
    <item>
      <title>For Each Update Loop?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389616#M93421</link>
      <description>&lt;P&gt;In SAS is there an equivalent of&lt;/P&gt;&lt;P&gt;For each employee id do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; LastVariable;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Variable[1-10];&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; For I =1 to I = 10 do;&lt;/P&gt;&lt;P&gt;&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; If variable(i) is null then&amp;nbsp; then Variable(i) = LastVariable;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; End;&lt;/P&gt;&lt;P&gt;End;&lt;/P&gt;&lt;P&gt;I’m trying to update a set of records using the last real value where the value to fill null values further in the series.&lt;/P&gt;</description>
      <pubDate>Mon, 21 Aug 2017 19:02:06 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389616#M93421</guid>
      <dc:creator>DavidPhillips2</dc:creator>
      <dc:date>2017-08-21T19:02:06Z</dc:date>
    </item>
    <item>
      <title>Re: For Each Update Loop?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389619#M93424</link>
      <description>&lt;P&gt;Providing a little example data and the desired result will help. "Last variable" without some context may take a lot of verbiage where example data is more concrete. You would not need to provide all 10 variables, 3 or 4 should suffice to show the logic needed.&lt;/P&gt;</description>
      <pubDate>Mon, 21 Aug 2017 19:05:58 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389619#M93424</guid>
      <dc:creator>ballardw</dc:creator>
      <dc:date>2017-08-21T19:05:58Z</dc:date>
    </item>
    <item>
      <title>Re: For Each Update Loop?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389621#M93425</link>
      <description>&lt;P&gt;Ballardw, the 10 variables are an arrary.&lt;/P&gt;</description>
      <pubDate>Mon, 21 Aug 2017 19:07:36 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389621#M93425</guid>
      <dc:creator>DavidPhillips2</dc:creator>
      <dc:date>2017-08-21T19:07:36Z</dc:date>
    </item>
    <item>
      <title>Re: For Each Update Loop?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389629#M93428</link>
      <description>&lt;P&gt;Your question:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;BLOCKQUOTE&gt;
&lt;P&gt;&lt;STRONG&gt;In SAS is there an equivalent of&lt;/STRONG&gt;&lt;/P&gt;
&lt;P&gt;For each employee id do;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; LastVariable;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Variable[1-10];&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; For I =1 to I = 10 do;&lt;/P&gt;
&lt;P&gt;&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; If variable(i) is null then&amp;nbsp; then Variable(i) = LastVariable;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; End;&lt;/P&gt;
&lt;P&gt;End;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;/BLOCKQUOTE&gt;
&lt;P&gt;My answer: &lt;STRONG&gt;Yes, SAS has an equivalent&lt;/STRONG&gt;. Very close to your 'code' as well.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;If you need help on how to code this post more detailed information, including sample data and expected output.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Otherwise see this page on arrays and how to use them:&lt;/P&gt;
&lt;P&gt;&lt;A href="https://stats.idre.ucla.edu/sas/seminars/sas-arrays/" target="_blank"&gt;https://stats.idre.ucla.edu/sas/seminars/sas-arrays/&lt;/A&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I don't think any of them exactly match your situation but they should give you an idea.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;</description>
      <pubDate>Mon, 21 Aug 2017 19:21:04 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389629#M93428</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2017-08-21T19:21:04Z</dc:date>
    </item>
    <item>
      <title>Re: For Each Update Loop?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389668#M93440</link>
      <description>&lt;P&gt;data class2; set sashelp.class;&lt;BR /&gt;if weight &amp;gt; 100 then age = .;&lt;BR /&gt;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;proc sort data=class2;&lt;BR /&gt;by sex descending age ;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;data class2; set class2;&lt;BR /&gt;if age = 12 then age = .;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;For both genders, I am trying to fill the age with the age before it if it is blank.&lt;/P&gt;</description>
      <pubDate>Mon, 21 Aug 2017 21:00:08 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389668#M93440</guid>
      <dc:creator>DavidPhillips2</dc:creator>
      <dc:date>2017-08-21T21:00:08Z</dc:date>
    </item>
    <item>
      <title>Re: For Each Update Loop?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389671#M93441</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data class_want;
set class2;
by sex;
retain age_filled;
if first.sex then age_filled=.;


if age ne . then age_filled=age;

run;
 &lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 21 Aug 2017 21:18:28 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/389671#M93441</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2017-08-21T21:18:28Z</dc:date>
    </item>
    <item>
      <title>Re: For Each Update Loop?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/390220#M93579</link>
      <description>&lt;P&gt;Minor enhancement:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;data class2; set sashelp.class;&lt;BR /&gt;if weight &amp;gt; 100 then age = .;&lt;/P&gt;&lt;P&gt;run;&lt;BR /&gt;proc sort data=class2;&lt;BR /&gt;by sex descending age ;&lt;BR /&gt;run;&lt;BR /&gt;data class2; set class2;&lt;BR /&gt;if age = 12 then age = .;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;data class_want (drop=age rename=(age_filled =age) );&lt;BR /&gt;set class2;&lt;BR /&gt;by sex;&lt;BR /&gt;retain age_filled;&lt;BR /&gt;if first.sex then age_filled=.;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;if age ne . then age_filled=age;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;</description>
      <pubDate>Wed, 23 Aug 2017 13:04:55 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/For-Each-Update-Loop/m-p/390220#M93579</guid>
      <dc:creator>DavidPhillips2</dc:creator>
      <dc:date>2017-08-23T13:04:55Z</dc:date>
    </item>
  </channel>
</rss>

