<?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 avoid to repeat data step in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/avoid-to-repeat-data-step/m-p/642248#M191564</link>
    <description>&lt;P&gt;good day,&lt;/P&gt;
&lt;P&gt;below is my program structure;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; test1 test2&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;Expected net&lt;/P&gt;
&lt;P&gt;row1&amp;nbsp; &amp;nbsp; &amp;nbsp; 100&amp;nbsp; 90&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;10&lt;/P&gt;
&lt;P&gt;row2&amp;nbsp; &amp;nbsp; &amp;nbsp; 99&amp;nbsp; &amp;nbsp; 90&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; 9&lt;/P&gt;
&lt;P&gt;row3&amp;nbsp; &amp;nbsp; &amp;nbsp; 98&amp;nbsp; &amp;nbsp; 90&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; 8&lt;/P&gt;
&lt;P&gt;row4&amp;nbsp; &amp;nbsp; &amp;nbsp; 97&amp;nbsp; &amp;nbsp; 90&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; 7&lt;/P&gt;
&lt;P&gt;net=test1-test2;&lt;/P&gt;
&lt;P&gt;if row(n) net=10 then row(n+1) test1 = 100 ;&lt;/P&gt;
&lt;P&gt;if row(n) net=10 then row(n+1) test2 = 90 ;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P style="line-height: 1.71429;"&gt;the problem is when the SAS condition change row2 test1=100 and test2=90&lt;/P&gt;
&lt;P style="line-height: 1.71429;"&gt;you have to rerun the data step and get the correct net for row2&lt;/P&gt;
&lt;P style="line-height: 1.71429;"&gt;and after that row3 can meet the condition and make its changing&lt;/P&gt;
&lt;P style="line-height: 1.71429;"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;expected result:&lt;/P&gt;
&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; test1 test2&amp;nbsp; net&lt;/P&gt;
&lt;P&gt;row1&amp;nbsp; &amp;nbsp; 100&amp;nbsp; 90&amp;nbsp; &amp;nbsp; &amp;nbsp; 10&lt;/P&gt;
&lt;P&gt;row2&amp;nbsp; &amp;nbsp; 100&amp;nbsp; 90&amp;nbsp; &amp;nbsp; &amp;nbsp; 10&lt;/P&gt;
&lt;P&gt;row3&amp;nbsp; &amp;nbsp; 100&amp;nbsp; 90&amp;nbsp; &amp;nbsp; &amp;nbsp; 10&lt;/P&gt;
&lt;P&gt;row4&amp;nbsp; &amp;nbsp; 100&amp;nbsp; 90&amp;nbsp; &amp;nbsp; &amp;nbsp; 10&lt;/P&gt;
&lt;P&gt;the only solution i can figure out for now is manually run this script for 3 times then i can get my expected result.&lt;/P&gt;
&lt;P&gt;so i am going to seek help in this forum.&lt;/P&gt;
&lt;P&gt;anyone get a better way to do it?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Thanks in advance,&lt;/P&gt;
&lt;P&gt;Harry&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Thu, 23 Apr 2020 14:29:52 GMT</pubDate>
    <dc:creator>harrylui</dc:creator>
    <dc:date>2020-04-23T14:29:52Z</dc:date>
    <item>
      <title>avoid to repeat data step</title>
      <link>https://communities.sas.com/t5/SAS-Programming/avoid-to-repeat-data-step/m-p/642248#M191564</link>
      <description>&lt;P&gt;good day,&lt;/P&gt;
&lt;P&gt;below is my program structure;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; test1 test2&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;Expected net&lt;/P&gt;
&lt;P&gt;row1&amp;nbsp; &amp;nbsp; &amp;nbsp; 100&amp;nbsp; 90&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;10&lt;/P&gt;
&lt;P&gt;row2&amp;nbsp; &amp;nbsp; &amp;nbsp; 99&amp;nbsp; &amp;nbsp; 90&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; 9&lt;/P&gt;
&lt;P&gt;row3&amp;nbsp; &amp;nbsp; &amp;nbsp; 98&amp;nbsp; &amp;nbsp; 90&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; 8&lt;/P&gt;
&lt;P&gt;row4&amp;nbsp; &amp;nbsp; &amp;nbsp; 97&amp;nbsp; &amp;nbsp; 90&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; 7&lt;/P&gt;
&lt;P&gt;net=test1-test2;&lt;/P&gt;
&lt;P&gt;if row(n) net=10 then row(n+1) test1 = 100 ;&lt;/P&gt;
&lt;P&gt;if row(n) net=10 then row(n+1) test2 = 90 ;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P style="line-height: 1.71429;"&gt;the problem is when the SAS condition change row2 test1=100 and test2=90&lt;/P&gt;
&lt;P style="line-height: 1.71429;"&gt;you have to rerun the data step and get the correct net for row2&lt;/P&gt;
&lt;P style="line-height: 1.71429;"&gt;and after that row3 can meet the condition and make its changing&lt;/P&gt;
&lt;P style="line-height: 1.71429;"&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;expected result:&lt;/P&gt;
&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; test1 test2&amp;nbsp; net&lt;/P&gt;
&lt;P&gt;row1&amp;nbsp; &amp;nbsp; 100&amp;nbsp; 90&amp;nbsp; &amp;nbsp; &amp;nbsp; 10&lt;/P&gt;
&lt;P&gt;row2&amp;nbsp; &amp;nbsp; 100&amp;nbsp; 90&amp;nbsp; &amp;nbsp; &amp;nbsp; 10&lt;/P&gt;
&lt;P&gt;row3&amp;nbsp; &amp;nbsp; 100&amp;nbsp; 90&amp;nbsp; &amp;nbsp; &amp;nbsp; 10&lt;/P&gt;
&lt;P&gt;row4&amp;nbsp; &amp;nbsp; 100&amp;nbsp; 90&amp;nbsp; &amp;nbsp; &amp;nbsp; 10&lt;/P&gt;
&lt;P&gt;the only solution i can figure out for now is manually run this script for 3 times then i can get my expected result.&lt;/P&gt;
&lt;P&gt;so i am going to seek help in this forum.&lt;/P&gt;
&lt;P&gt;anyone get a better way to do it?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Thanks in advance,&lt;/P&gt;
&lt;P&gt;Harry&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 23 Apr 2020 14:29:52 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/avoid-to-repeat-data-step/m-p/642248#M191564</guid>
      <dc:creator>harrylui</dc:creator>
      <dc:date>2020-04-23T14:29:52Z</dc:date>
    </item>
    <item>
      <title>Re: avoid to repeat data step</title>
      <link>https://communities.sas.com/t5/SAS-Programming/avoid-to-repeat-data-step/m-p/642254#M191566</link>
      <description>&lt;P&gt;Hi&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/107435"&gt;@harrylui&lt;/a&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Does the following code could meet your expectations?&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
	input test1 test2;
	datalines;
100 90
99 90
98 90
97 90
;
run;

data want;
	set have;
	if _n_=1 then net=test1-test2;
	retain net;
	test1 = 100;
	test2 = 90;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Thu, 23 Apr 2020 14:37:57 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/avoid-to-repeat-data-step/m-p/642254#M191566</guid>
      <dc:creator>ed_sas_member</dc:creator>
      <dc:date>2020-04-23T14:37:57Z</dc:date>
    </item>
  </channel>
</rss>

