<?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: getting average in a column in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467203#M119259</link>
    <description>&lt;P&gt;Thanks for your reply.&lt;BR /&gt;Based on the data set i think instead of using proc sql, grouping, I use this code.&lt;BR /&gt;I want to create a variable by some condition. first group observations with the same var1. then if var2 is 1 the 'want var' is the same as var 3. if var 2 is 0 'want var' is the average of var 3.&lt;BR /&gt;for obs 1-3:&lt;BR /&gt;obs var1 var2 var 3 want&lt;BR /&gt;1 1 0 20 15 ((20+10)/2)&lt;BR /&gt;2 1 0 10 15&lt;BR /&gt;3 1 1 20 20&lt;/P&gt;</description>
    <pubDate>Sun, 03 Jun 2018 03:58:02 GMT</pubDate>
    <dc:creator>ali_far</dc:creator>
    <dc:date>2018-06-03T03:58:02Z</dc:date>
    <item>
      <title>getting average in a column</title>
      <link>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467194#M119256</link>
      <description>&lt;P&gt;Hi all,&lt;/P&gt;&lt;P&gt;I have a question about this code. it is about getting average in a column.&lt;/P&gt;&lt;P&gt;your help is appreciated.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;obs&amp;nbsp; Var1 &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Var2&amp;nbsp;&amp;nbsp;&amp;nbsp; Var3&lt;/P&gt;&lt;P&gt;1&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; 0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 20&lt;/P&gt;&lt;P&gt;2&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; 0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 10&lt;/P&gt;&lt;P&gt;3&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; 1&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp; &amp;nbsp; 20&lt;/P&gt;&lt;P&gt;4&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; 0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; 20&lt;/P&gt;&lt;P&gt;5&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; 0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp; 10&lt;/P&gt;&lt;P&gt;6&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;&amp;nbsp; 1&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp; 30&lt;/P&gt;&lt;P&gt;.&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .&lt;/P&gt;&lt;P&gt;.&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .&lt;/P&gt;&lt;P&gt;data want;&lt;/P&gt;&lt;P&gt;set&amp;nbsp; have;&lt;/P&gt;&lt;P&gt;if var1=lag(var1) then do;&lt;/P&gt;&lt;P&gt;if Var2=1 then want=var3;&lt;/P&gt;&lt;P&gt;if var2=0 then want=mean(var3); /*this line did not perform*/&lt;/P&gt;&lt;P&gt;end;run;&lt;/P&gt;</description>
      <pubDate>Sun, 03 Jun 2018 03:19:09 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467194#M119256</guid>
      <dc:creator>ali_far</dc:creator>
      <dc:date>2018-06-03T03:19:09Z</dc:date>
    </item>
    <item>
      <title>Re: getting average in a column</title>
      <link>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467195#M119257</link>
      <description>&lt;P&gt;The MEAN() function works on a single row of data, so the mean of a value is the same value.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Rather than use var1=lag(var1) I suggest reviewing how BY group processing works and letting SAS handle the grouping transitions for you instead of coding it manually. It's a very powerful feature.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;It's not clear exactly what you want, if you want more than an explanation of why it isn't working, please show what you are expecting as output from the input and the logic required.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/149294"&gt;@ali_far&lt;/a&gt;&amp;nbsp;wrote:&lt;BR /&gt;
&lt;P&gt;Hi all,&lt;/P&gt;
&lt;P&gt;I have a question about this code. it is about getting average in a column.&lt;/P&gt;
&lt;P&gt;your help is appreciated.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;obs&amp;nbsp; Var1 &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Var2&amp;nbsp;&amp;nbsp;&amp;nbsp; Var3&lt;/P&gt;
&lt;P&gt;1&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; 0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 20&lt;/P&gt;
&lt;P&gt;2&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; 0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 10&lt;/P&gt;
&lt;P&gt;3&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; 1&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp; &amp;nbsp; 20&lt;/P&gt;
&lt;P&gt;4&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; 0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp; 20&lt;/P&gt;
&lt;P&gt;5&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; 0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp; 10&lt;/P&gt;
&lt;P&gt;6&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;&amp;nbsp; 1&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp; 30&lt;/P&gt;
&lt;P&gt;.&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .&lt;/P&gt;
&lt;P&gt;.&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; .&lt;/P&gt;
&lt;P&gt;data want;&lt;/P&gt;
&lt;P&gt;set&amp;nbsp; have;&lt;/P&gt;
&lt;P&gt;if var1=lag(var1) then do;&lt;/P&gt;
&lt;P&gt;if Var2=1 then want=var3;&lt;/P&gt;
&lt;P&gt;if var2=0 then want=mean(var3); /*this line did not perform*/&lt;/P&gt;
&lt;P&gt;end;run;&lt;/P&gt;
&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Sun, 03 Jun 2018 03:23:40 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467195#M119257</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2018-06-03T03:23:40Z</dc:date>
    </item>
    <item>
      <title>Re: getting average in a column</title>
      <link>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467198#M119258</link>
      <description>Thanks for your reply.&lt;BR /&gt;Based on the data set i think instead of using proc sql, grouping, I use this code.&lt;BR /&gt;I want to create a variable by some condition. first group observations with the same var1. then if var2 is 1 the 'want var' is the same as var 3. if var 2 is 0 'want var' is the average of var 3.&lt;BR /&gt;for obs 1-3:&lt;BR /&gt;obs var1 var2 var 3 want&lt;BR /&gt;1 1 0 20 15 ((20+10)/2)&lt;BR /&gt;2 1 0 10 15&lt;BR /&gt;3 1 1 20 20&lt;BR /&gt;</description>
      <pubDate>Sun, 03 Jun 2018 03:40:47 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467198#M119258</guid>
      <dc:creator>ali_far</dc:creator>
      <dc:date>2018-06-03T03:40:47Z</dc:date>
    </item>
    <item>
      <title>Re: getting average in a column</title>
      <link>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467203#M119259</link>
      <description>&lt;P&gt;Thanks for your reply.&lt;BR /&gt;Based on the data set i think instead of using proc sql, grouping, I use this code.&lt;BR /&gt;I want to create a variable by some condition. first group observations with the same var1. then if var2 is 1 the 'want var' is the same as var 3. if var 2 is 0 'want var' is the average of var 3.&lt;BR /&gt;for obs 1-3:&lt;BR /&gt;obs var1 var2 var 3 want&lt;BR /&gt;1 1 0 20 15 ((20+10)/2)&lt;BR /&gt;2 1 0 10 15&lt;BR /&gt;3 1 1 20 20&lt;/P&gt;</description>
      <pubDate>Sun, 03 Jun 2018 03:58:02 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467203#M119259</guid>
      <dc:creator>ali_far</dc:creator>
      <dc:date>2018-06-03T03:58:02Z</dc:date>
    </item>
    <item>
      <title>Re: getting average in a column</title>
      <link>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467204#M119260</link>
      <description>&lt;P&gt;A SQL approach will likely be the easiest, possibly a single step solution. A data step solution will be more than one step.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;1. Add the average value to each row so it's available, easily done in SQL&lt;/P&gt;
&lt;P&gt;&lt;A href="https://github.com/statgeek/SAS-Tutorials/blob/master/add_average_value_to_dataset.sas" target="_blank"&gt;https://github.com/statgeek/SAS-Tutorials/blob/master/add_average_value_to_dataset.sas&lt;/A&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;2. Add a case statement to do the assignment.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql;
create table want (drop=avg_Var) as
select *, 
    mean(var3) as avg_var, 
    case when var2=0 then calculated avg_var 
    else var3 
    end as new_var
from have
group by var1;
quit;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/149294"&gt;@ali_far&lt;/a&gt;&amp;nbsp;wrote:&lt;BR /&gt;Thanks for your reply.&lt;BR /&gt;Based on the data set i think instead of using proc sql, grouping, I use this code.&lt;BR /&gt;I want to create a variable by some condition. first group observations with the same var1. then if var2 is 1 the 'want var' is the same as var 3. if var 2 is 0 'want var' is the average of var 3.&lt;BR /&gt;for obs 1-3:&lt;BR /&gt;obs var1 var2 var 3 want&lt;BR /&gt;1 1 0 20 15 ((20+10)/2)&lt;BR /&gt;2 1 0 10 15&lt;BR /&gt;3 1 1 20 20&lt;BR /&gt;&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Sun, 03 Jun 2018 04:13:37 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467204#M119260</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2018-06-03T04:13:37Z</dc:date>
    </item>
    <item>
      <title>Re: getting average in a column</title>
      <link>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467206#M119261</link>
      <description>&lt;P&gt;Thanks&amp;nbsp; for your reply. However, the code calculates the mean of var3 where var2 in (1,2).&lt;/P&gt;&lt;P&gt;However, I want the mean of var3 where var2=0&amp;nbsp; and else var3..&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I appreciate your help&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Sun, 03 Jun 2018 05:07:20 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/getting-average-in-a-column/m-p/467206#M119261</guid>
      <dc:creator>ali_far</dc:creator>
      <dc:date>2018-06-03T05:07:20Z</dc:date>
    </item>
  </channel>
</rss>

