<?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: how to calculate sum group wise in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490401#M128297</link>
    <description>&lt;P&gt;That can also be done reading the data just once:&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
  set s1;
  by id;
  _sum+dose;
  if last.id then do;
    sum=_sum;
    _sum=0;
    end;
  drop _sum;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Tue, 28 Aug 2018 10:26:09 GMT</pubDate>
    <dc:creator>s_lassen</dc:creator>
    <dc:date>2018-08-28T10:26:09Z</dc:date>
    <item>
      <title>how to calculate sum group wise</title>
      <link>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490335#M128260</link>
      <description>&lt;P&gt;data s1 ;&lt;BR /&gt;input id $ dose ;&lt;BR /&gt;cards ;&lt;BR /&gt;101 22&lt;BR /&gt;101 23&lt;BR /&gt;101 24&lt;BR /&gt;102 43&lt;BR /&gt;102 23&lt;BR /&gt;102 11&lt;BR /&gt;102 22&lt;BR /&gt;103 22&lt;BR /&gt;103 22&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;i have date like see above&lt;/P&gt;&lt;P&gt;i want to data keep like see below&amp;nbsp;&lt;/P&gt;&lt;P&gt;group(id) wise sum&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;&lt;STRONG&gt;id&lt;/STRONG&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;&lt;STRONG&gt;dose&lt;/STRONG&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;&lt;STRONG&gt;total&lt;/STRONG&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;101&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;23&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;69&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;101&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;24&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;.&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;101&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;22&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;.&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;102&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;11&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;99&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;102&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;22&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;.&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;102&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;23&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;.&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;102&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;43&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;.&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;103&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;22&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;44&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;103&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;22&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;.&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;</description>
      <pubDate>Tue, 28 Aug 2018 05:57:10 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490335#M128260</guid>
      <dc:creator>thanikondharish</dc:creator>
      <dc:date>2018-08-28T05:57:10Z</dc:date>
    </item>
    <item>
      <title>Re: how to calculate sum group wise</title>
      <link>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490344#M128268</link>
      <description>&lt;P&gt;Create a separate sums table, and do a merge with a twist:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input id $ dose;
cards;
101 22
101 23
101 24
102 43
102 23
102 11
102 22
103 22
103 22
;
run;

proc sql;
create table sums as
select id, sum(dose) as total
from have
group by id;
quit;

data want;
merge
  have
  sums
;
by id;
if not first.id then total = .;
run;

proc print data=want noobs;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Result:&lt;/P&gt;
&lt;PRE&gt;id     dose    total

101     22       69 
101     23        . 
101     24        . 
102     43       99 
102     23        . 
102     11        . 
102     22        . 
103     22       44 
103     22        . 
&lt;/PRE&gt;
&lt;P&gt;Alternatively, you could reverse the order within the groups, sum and set total at last.id, and reverse the order back to original.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 28 Aug 2018 06:50:35 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490344#M128268</guid>
      <dc:creator>Kurt_Bremser</dc:creator>
      <dc:date>2018-08-28T06:50:35Z</dc:date>
    </item>
    <item>
      <title>Re: how to calculate sum group wise</title>
      <link>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490350#M128273</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;I am doing for you alternative part, by taking reference from &lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/11562"&gt;@Kurt_Bremser&lt;/a&gt; and add little flavor of &lt;BR /&gt;retain.&lt;BR /&gt;&lt;BR /&gt;proc sort data=s1;
 by id descending dose;
run;

data s2;
 set s1;
 by id descending dose;
 retain total ;
 if first.id then total=dose;
 else total+dose;
 if last.id;
 keep id total;
run;

data s2;
merge s2 s1;
by id;
if  first.id then newvar=total;
else newvar=.;
drop total;
rename newvar=total;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 28 Aug 2018 07:19:01 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490350#M128273</guid>
      <dc:creator>shahparth260</dc:creator>
      <dc:date>2018-08-28T07:19:01Z</dc:date>
    </item>
    <item>
      <title>Re: how to calculate sum group wise</title>
      <link>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490366#M128278</link>
      <description>&lt;P&gt;Another way is to use DOW. Two double do-loops get it. The presorted Data Set is assumed.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
   do until(last.id);
      set have;
      by id notsorted;
      sum + dose;
   end;
   do until(last.id);
      set have;
      by id notsorted;
      if not first.id then sum = .;
      output;
  end;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;HTH&lt;/P&gt;
&lt;P&gt;Cheers&lt;/P&gt;
&lt;P&gt;DATASP&lt;/P&gt;</description>
      <pubDate>Tue, 28 Aug 2018 07:56:49 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490366#M128278</guid>
      <dc:creator>KachiM</dc:creator>
      <dc:date>2018-08-28T07:56:49Z</dc:date>
    </item>
    <item>
      <title>Re: how to calculate sum group wise</title>
      <link>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490401#M128297</link>
      <description>&lt;P&gt;That can also be done reading the data just once:&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
  set s1;
  by id;
  _sum+dose;
  if last.id then do;
    sum=_sum;
    _sum=0;
    end;
  drop _sum;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 28 Aug 2018 10:26:09 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490401#M128297</guid>
      <dc:creator>s_lassen</dc:creator>
      <dc:date>2018-08-28T10:26:09Z</dc:date>
    </item>
    <item>
      <title>Re: how to calculate sum group wise</title>
      <link>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490404#M128298</link>
      <description>&lt;P&gt;You shouldn't have to write your own code to compute group sums. PROC SUMMARY will do this, then you can merge the results into the original data set.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;All of the examples above where a DATA step is used to compute the sum have a potential error ... if there is a missing value in the variable to be summed, all the examples above result in a missing sum. This doesn't happen with PROC SUMMARY. (It can also be fixed in the data step if necessary).&lt;/P&gt;</description>
      <pubDate>Tue, 28 Aug 2018 12:02:08 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490404#M128298</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2018-08-28T12:02:08Z</dc:date>
    </item>
    <item>
      <title>Re: how to calculate sum group wise</title>
      <link>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490444#M128308</link>
      <description>&lt;P&gt;Your observation on the presence of missing values is not true as I have used SUM statement. Here is a test:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input id $ dose;
cards;
101 22
101 23
101  .
101 24
102 43
102 23
102 11
102 22
103 22
103  .
103 22
;
run;

data want;
   do until(last.id);
      set have;
      by id notsorted;
      sum + dose;
   end;
   do until(last.id);
      set have;
      by id notsorted;
      if not first.id then sum = .;
      output;
  end;
run;

Obs 	id 	dose 	sum
1 	101 	22 	69
2 	101 	23 	.
3 	101 	. 	.
4 	101 	24 	.
5 	102 	43 	99
6 	102 	23 	.
7 	102 	11 	.
8 	102 	22 	.
9 	103 	22 	44
10 	103 	. 	.
11 	103 	22 	.
&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 28 Aug 2018 13:12:30 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490444#M128308</guid>
      <dc:creator>KachiM</dc:creator>
      <dc:date>2018-08-28T13:12:30Z</dc:date>
    </item>
    <item>
      <title>Re: how to calculate sum group wise</title>
      <link>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490446#M128309</link>
      <description>&lt;P&gt;Thanks. I was not aware of that.&lt;/P&gt;</description>
      <pubDate>Tue, 28 Aug 2018 13:20:08 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/how-to-calculate-sum-group-wise/m-p/490446#M128309</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2018-08-28T13:20:08Z</dc:date>
    </item>
  </channel>
</rss>

