<?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: AVERAGE OF A VARIABLE NUMBER OF VALUES in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602967#M174639</link>
    <description>&lt;P&gt;thank you!! it works great! thank you also for the sugestions regarding the two dash list indicator.&lt;/P&gt;</description>
    <pubDate>Sat, 09 Nov 2019 10:42:27 GMT</pubDate>
    <dc:creator>mahele</dc:creator>
    <dc:date>2019-11-09T10:42:27Z</dc:date>
    <item>
      <title>AVERAGE OF A VARIABLE NUMBER OF VALUES</title>
      <link>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602703#M174525</link>
      <description>&lt;P&gt;Hi everyone.&lt;BR /&gt;My SAS version is 9.4 and I have a dataset with 128967 observations, for each obs i have a date variable (dd/mm/yyyy)&amp;nbsp; and 12 months of amounts (IMPO_1 -- IMPO_12). Here is a subset of my dataset:&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Oss&lt;/TD&gt;&lt;TD&gt;DATA_DEC&lt;/TD&gt;&lt;TD&gt;IMPO_1&lt;/TD&gt;&lt;TD&gt;IMPO_2&lt;/TD&gt;&lt;TD&gt;IMPO_3&lt;/TD&gt;&lt;TD&gt;IMPO_4&lt;/TD&gt;&lt;TD&gt;IMPO_5&lt;/TD&gt;&lt;TD&gt;IMPO_6&lt;/TD&gt;&lt;TD&gt;IMPO_7&lt;/TD&gt;&lt;TD&gt;IMPO_8&lt;/TD&gt;&lt;TD&gt;IMPO_9&lt;/TD&gt;&lt;TD&gt;IMPO_10&lt;/TD&gt;&lt;TD&gt;IMPO_11&lt;/TD&gt;&lt;TD&gt;IMPO_12&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;15/01/2018&lt;/TD&gt;&lt;TD&gt;549,78&lt;/TD&gt;&lt;TD&gt;547,07&lt;/TD&gt;&lt;TD&gt;544,71&lt;/TD&gt;&lt;TD&gt;542,36&lt;/TD&gt;&lt;TD&gt;539,84&lt;/TD&gt;&lt;TD&gt;537,32&lt;/TD&gt;&lt;TD&gt;534,8&lt;/TD&gt;&lt;TD&gt;532,28&lt;/TD&gt;&lt;TD&gt;530,75&lt;/TD&gt;&lt;TD&gt;529,45&lt;/TD&gt;&lt;TD&gt;527,86&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;TD&gt;25/05/2009&lt;/TD&gt;&lt;TD&gt;3.707,41&lt;/TD&gt;&lt;TD&gt;3.701,80&lt;/TD&gt;&lt;TD&gt;3.695,14&lt;/TD&gt;&lt;TD&gt;3.689,64&lt;/TD&gt;&lt;TD&gt;3.719,15&lt;/TD&gt;&lt;TD&gt;3.748,20&lt;/TD&gt;&lt;TD&gt;3.742,56&lt;/TD&gt;&lt;TD&gt;3.737,02&lt;/TD&gt;&lt;TD&gt;3.725,50&lt;/TD&gt;&lt;TD&gt;3.742,90&lt;/TD&gt;&lt;TD&gt;3.731,60&lt;/TD&gt;&lt;TD&gt;3.726,50&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;10/07/2009&lt;/TD&gt;&lt;TD&gt;307,2&lt;/TD&gt;&lt;TD&gt;306,4&lt;/TD&gt;&lt;TD&gt;301,5&lt;/TD&gt;&lt;TD&gt;310,5&lt;/TD&gt;&lt;TD&gt;312,23&lt;/TD&gt;&lt;TD&gt;309,45&lt;/TD&gt;&lt;TD&gt;305,12&lt;/TD&gt;&lt;TD&gt;301,23&lt;/TD&gt;&lt;TD&gt;307,25&lt;/TD&gt;&lt;TD&gt;289,56&lt;/TD&gt;&lt;TD&gt;286,25&lt;/TD&gt;&lt;TD&gt;215,9&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;TD&gt;15/04/2014&lt;/TD&gt;&lt;TD&gt;53,35&lt;/TD&gt;&lt;TD&gt;53,06&lt;/TD&gt;&lt;TD&gt;51,07&lt;/TD&gt;&lt;TD&gt;51,35&lt;/TD&gt;&lt;TD&gt;57,35&lt;/TD&gt;&lt;TD&gt;55,01&lt;/TD&gt;&lt;TD&gt;51,26&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;5&lt;/TD&gt;&lt;TD&gt;05/03/2009&lt;/TD&gt;&lt;TD&gt;121,16&lt;/TD&gt;&lt;TD&gt;119,48&lt;/TD&gt;&lt;TD&gt;114&lt;/TD&gt;&lt;TD&gt;100,89&lt;/TD&gt;&lt;TD&gt;85,82&lt;/TD&gt;&lt;TD&gt;76,43&lt;/TD&gt;&lt;TD&gt;82,31&lt;/TD&gt;&lt;TD&gt;76,71&lt;/TD&gt;&lt;TD&gt;76,25&lt;/TD&gt;&lt;TD&gt;74,69&lt;/TD&gt;&lt;TD&gt;75,14&lt;/TD&gt;&lt;TD&gt;73,12&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;For each observation I need to calculate the average of a variable number of 'IMPO_', this number of 'IMPO_' depends on month(DATA_DEC).&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;For example:&lt;/P&gt;&lt;P&gt;- for the first obs the&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; MONTH(DATA_DEC)=1 so AVERAGE=MEAN(IMPO_1);&lt;/P&gt;&lt;P&gt;- for the second obs the&amp;nbsp;&amp;nbsp; MONTH(DATA_DEC)=5 so AVERAGE=MEAN(OF IMPO_1 -- IMPO_5);&lt;/P&gt;&lt;P&gt;- for the third obs the&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; MONTH(DATA_DEC)=7 so AVERAGE=MEAN(OF IMPO_1 -- IMPO_7);&lt;/P&gt;&lt;P&gt;.... and so on for &lt;STRONG&gt;each of 128967&lt;/STRONG&gt; observations.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;My wanted dataset needs to be like:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Oss&lt;/TD&gt;&lt;TD&gt;DATA_DEC&lt;/TD&gt;&lt;TD&gt;IMPO_1&lt;/TD&gt;&lt;TD&gt;IMPO_2&lt;/TD&gt;&lt;TD&gt;IMPO_3&lt;/TD&gt;&lt;TD&gt;IMPO_4&lt;/TD&gt;&lt;TD&gt;IMPO_5&lt;/TD&gt;&lt;TD&gt;IMPO_6&lt;/TD&gt;&lt;TD&gt;IMPO_7&lt;/TD&gt;&lt;TD&gt;IMPO_8&lt;/TD&gt;&lt;TD&gt;IMPO_9&lt;/TD&gt;&lt;TD&gt;IMPO_10&lt;/TD&gt;&lt;TD&gt;IMPO_11&lt;/TD&gt;&lt;TD&gt;IMPO_12&lt;/TD&gt;&lt;TD&gt;&lt;STRONG&gt;AVERAGE&lt;/STRONG&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;15/01/2018&lt;/TD&gt;&lt;TD&gt;549,78&lt;/TD&gt;&lt;TD&gt;547,07&lt;/TD&gt;&lt;TD&gt;544,71&lt;/TD&gt;&lt;TD&gt;542,36&lt;/TD&gt;&lt;TD&gt;539,84&lt;/TD&gt;&lt;TD&gt;537,32&lt;/TD&gt;&lt;TD&gt;534,8&lt;/TD&gt;&lt;TD&gt;532,28&lt;/TD&gt;&lt;TD&gt;530,75&lt;/TD&gt;&lt;TD&gt;529,45&lt;/TD&gt;&lt;TD&gt;527,86&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;STRONG&gt;549,78&lt;/STRONG&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;TD&gt;25/05/2009&lt;/TD&gt;&lt;TD&gt;3.707,41&lt;/TD&gt;&lt;TD&gt;3.701,80&lt;/TD&gt;&lt;TD&gt;3.695,14&lt;/TD&gt;&lt;TD&gt;3.689,64&lt;/TD&gt;&lt;TD&gt;3.719,15&lt;/TD&gt;&lt;TD&gt;3.748,20&lt;/TD&gt;&lt;TD&gt;3.742,56&lt;/TD&gt;&lt;TD&gt;3.737,02&lt;/TD&gt;&lt;TD&gt;3.725,50&lt;/TD&gt;&lt;TD&gt;3.742,90&lt;/TD&gt;&lt;TD&gt;3.731,60&lt;/TD&gt;&lt;TD&gt;3.726,50&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;STRONG&gt;3.702,63&lt;/STRONG&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;10/07/2009&lt;/TD&gt;&lt;TD&gt;307,2&lt;/TD&gt;&lt;TD&gt;306,4&lt;/TD&gt;&lt;TD&gt;301,5&lt;/TD&gt;&lt;TD&gt;310,5&lt;/TD&gt;&lt;TD&gt;312,23&lt;/TD&gt;&lt;TD&gt;309,45&lt;/TD&gt;&lt;TD&gt;305,12&lt;/TD&gt;&lt;TD&gt;301,23&lt;/TD&gt;&lt;TD&gt;307,25&lt;/TD&gt;&lt;TD&gt;289,56&lt;/TD&gt;&lt;TD&gt;286,25&lt;/TD&gt;&lt;TD&gt;215,9&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;STRONG&gt;307,49&lt;/STRONG&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;TD&gt;15/04/2014&lt;/TD&gt;&lt;TD&gt;53,35&lt;/TD&gt;&lt;TD&gt;53,06&lt;/TD&gt;&lt;TD&gt;51,07&lt;/TD&gt;&lt;TD&gt;51,35&lt;/TD&gt;&lt;TD&gt;57,35&lt;/TD&gt;&lt;TD&gt;55,01&lt;/TD&gt;&lt;TD&gt;51,26&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;&lt;STRONG&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; 52,21&lt;/STRONG&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;5&lt;/TD&gt;&lt;TD&gt;05/03/2009&lt;/TD&gt;&lt;TD&gt;121,16&lt;/TD&gt;&lt;TD&gt;119,48&lt;/TD&gt;&lt;TD&gt;114&lt;/TD&gt;&lt;TD&gt;100,89&lt;/TD&gt;&lt;TD&gt;85,82&lt;/TD&gt;&lt;TD&gt;76,43&lt;/TD&gt;&lt;TD&gt;82,31&lt;/TD&gt;&lt;TD&gt;76,71&lt;/TD&gt;&lt;TD&gt;76,25&lt;/TD&gt;&lt;TD&gt;74,69&lt;/TD&gt;&lt;TD&gt;75,14&lt;/TD&gt;&lt;TD&gt;73,12&lt;/TD&gt;&lt;TD&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 118,21&lt;/STRONG&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;How can i do this? I've tried creating a macro variable for each row, which holds the value of the month such as &amp;amp;month1, &amp;amp;month2...&amp;nbsp;&amp;nbsp; then referencing it in to the MEAN(OF IMPO_1 -- IMPO_&amp;amp;&amp;amp;&amp;amp;month&amp;amp;n) but for &lt;STRONG&gt;128967&lt;/STRONG&gt; rows this is madness.&lt;/P&gt;&lt;P&gt;Could someone help me please!!!&lt;BR /&gt;Thank you!&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 08 Nov 2019 10:48:06 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602703#M174525</guid>
      <dc:creator>mahele</dc:creator>
      <dc:date>2019-11-08T10:48:06Z</dc:date>
    </item>
    <item>
      <title>Re: AVERAGE OF A VARIABLE NUMBER OF VALUES</title>
      <link>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602722#M174532</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
 set have;
array t impo_1-impo_12;
 do i=1 to dim(t) until(i=month(data_dec));
 sum=sum(sum,t(i));
end;
avg=sum/i;
drop i;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;/*Or just*/&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;
data want;
 set have;
array t impo_1-impo_12;
 do i=1 to month(data_dec);
 sum=sum(sum,t(i));
end;
avg=sum/i;
drop i;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 08 Nov 2019 13:16:07 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602722#M174532</guid>
      <dc:creator>novinosrin</dc:creator>
      <dc:date>2019-11-08T13:16:07Z</dc:date>
    </item>
    <item>
      <title>Re: AVERAGE OF A VARIABLE NUMBER OF VALUES</title>
      <link>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602741#M174539</link>
      <description>Good idea to use arrays, but ....&lt;BR /&gt;&lt;BR /&gt;The two variations look like they should generate different answers.  The denominator in the bottom solution is wrong.&lt;BR /&gt;&lt;BR /&gt;Also, it may be important to consider whether the data might contain missing values for some of the months.  Again, the denominator would be incorrect if that happens.</description>
      <pubDate>Fri, 08 Nov 2019 14:55:59 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602741#M174539</guid>
      <dc:creator>Astounding</dc:creator>
      <dc:date>2019-11-08T14:55:59Z</dc:date>
    </item>
    <item>
      <title>Re: AVERAGE OF A VARIABLE NUMBER OF VALUES</title>
      <link>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602755#M174546</link>
      <description>&lt;P&gt;Assuming that your data_dec is a SAS date value:&lt;/P&gt;
&lt;PRE&gt;data want;
 set have;
 select (month(data_dec));
   when (1) average= mean(impo_1);
   when (2) average= mean(of impo_1 -impo_2);
   when (3) average= mean(of impo_1 -impo_3);
   when (4) average= mean(of impo_1 -impo_4);
   when (5) average= mean(of impo_1 -impo_5);
   when (6) average= mean(of impo_1 -impo_6);
   when (7) average= mean(of impo_1 -impo_7);
   when (8) average= mean(of impo_1 -impo_8);
   when (9) average= mean(of impo_1 -impo_9);
   when (10) average= mean(of impo_1 -impo_10);
   when (11) average= mean(of impo_1 -impo_11);
   when (12) average= mean(of impo_1 -impo_12);
   otherwise;
 end;
run;&lt;/PRE&gt;
&lt;P&gt;The Select statement in this case evaluates an expression month(data_dec) and branches to the WHEN value that matches.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I would be careful of using the two dash list indicator in case anything changes the order of your data. You could end up with other values in the calculations. When you know that have sequentially named values it is better to use the single dash for the list.&lt;/P&gt;</description>
      <pubDate>Fri, 08 Nov 2019 15:39:36 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602755#M174546</guid>
      <dc:creator>ballardw</dc:creator>
      <dc:date>2019-11-08T15:39:36Z</dc:date>
    </item>
    <item>
      <title>Re: AVERAGE OF A VARIABLE NUMBER OF VALUES</title>
      <link>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602966#M174638</link>
      <description>&lt;P&gt;thank you so much!&lt;BR /&gt;the idea of using arrays is awsome! i introduced some&amp;nbsp; code changes&amp;nbsp; to manage&amp;nbsp; missing values.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
	set have;
	array t impo_1-impo_12;

	do i=1 to month(data_dec);
		sum=sum(sum, t(i));

		if t(i) &amp;lt;&amp;gt;. then
			den=i;
		avg=round(sum/den,0.01);
	end;
	drop i sum den;
run;

&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;and it works perfectly! thank you so much!&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Sat, 09 Nov 2019 10:37:24 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602966#M174638</guid>
      <dc:creator>mahele</dc:creator>
      <dc:date>2019-11-09T10:37:24Z</dc:date>
    </item>
    <item>
      <title>Re: AVERAGE OF A VARIABLE NUMBER OF VALUES</title>
      <link>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602967#M174639</link>
      <description>&lt;P&gt;thank you!! it works great! thank you also for the sugestions regarding the two dash list indicator.&lt;/P&gt;</description>
      <pubDate>Sat, 09 Nov 2019 10:42:27 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/AVERAGE-OF-A-VARIABLE-NUMBER-OF-VALUES/m-p/602967#M174639</guid>
      <dc:creator>mahele</dc:creator>
      <dc:date>2019-11-09T10:42:27Z</dc:date>
    </item>
  </channel>
</rss>

