<?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: Sum rows and column in Proc SQL in New SAS User</title>
    <link>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522091#M4354</link>
    <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;
data have;
input id $ measure1-measure3;
cards;
Id1	4	2	6
Id2	7	3	9
Id3	8	1	5
;

proc sql;
create table want as
select id,sum(measure1,measure2,measure3) as count, calculated count/sum( calculated count)*100 as pct
from have;
quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Tue, 18 Dec 2018 02:03:00 GMT</pubDate>
    <dc:creator>novinosrin</dc:creator>
    <dc:date>2018-12-18T02:03:00Z</dc:date>
    <item>
      <title>Sum rows and column in Proc SQL</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522086#M4352</link>
      <description>&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Say that I have a table like this:&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;Measure1&lt;/TD&gt;&lt;TD&gt;Measure2&lt;/TD&gt;&lt;TD&gt;Measure3&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Id1&lt;/TD&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;TD&gt;6&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Id2&lt;/TD&gt;&lt;TD&gt;7&lt;/TD&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;9&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Id3&lt;/TD&gt;&lt;TD&gt;8&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;5&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;And I want Proc SQL to output the following table:&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;Count&lt;/TD&gt;&lt;TD&gt;Percentage&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Id1&lt;/TD&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;26.7&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Id2&lt;/TD&gt;&lt;TD&gt;19&lt;/TD&gt;&lt;TD&gt;42.2&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Id3&lt;/TD&gt;&lt;TD&gt;14&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;31.1&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Count is a row's sum and percentage is a row's sum*100/column sum&amp;nbsp;of "Count". How can I go about doing this? Thank you in advance.&lt;/P&gt;</description>
      <pubDate>Tue, 18 Dec 2018 01:44:13 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522086#M4352</guid>
      <dc:creator>torvyle</dc:creator>
      <dc:date>2018-12-18T01:44:13Z</dc:date>
    </item>
    <item>
      <title>Re: Sum rows and column in Proc SQL</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522088#M4353</link>
      <description>Why the requirement to do it with SQL?</description>
      <pubDate>Tue, 18 Dec 2018 01:56:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522088#M4353</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2018-12-18T01:56:19Z</dc:date>
    </item>
    <item>
      <title>Re: Sum rows and column in Proc SQL</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522091#M4354</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;
data have;
input id $ measure1-measure3;
cards;
Id1	4	2	6
Id2	7	3	9
Id3	8	1	5
;

proc sql;
create table want as
select id,sum(measure1,measure2,measure3) as count, calculated count/sum( calculated count)*100 as pct
from have;
quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 18 Dec 2018 02:03:00 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522091#M4354</guid>
      <dc:creator>novinosrin</dc:creator>
      <dc:date>2018-12-18T02:03:00Z</dc:date>
    </item>
    <item>
      <title>Re: Sum rows and column in Proc SQL</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522092#M4355</link>
      <description>&lt;P&gt;or instead of *100, apply format percent.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;
data have;
input id $ measure1-measure3;
cards;
Id1	4	2	6
Id2	7	3	9
Id3	8	1	5
;

proc sql;
create table want as
select id,sum(measure1,measure2,measure3) as count, calculated count/sum( calculated count)  as pct format=percent.
from have;
quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 18 Dec 2018 02:04:36 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522092#M4355</guid>
      <dc:creator>novinosrin</dc:creator>
      <dc:date>2018-12-18T02:04:36Z</dc:date>
    </item>
    <item>
      <title>Re: Sum rows and column in Proc SQL</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522093#M4356</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql noprint;
	create table result as
		select (case when Measure1=. then 0 else Measure1 end)+
		       (case when Measure2=. then 0 else Measure2 end)+
			   (case when Measure3=. then 0 else Measure3 end) as count,
			   (case when calculated count in (.,0) then . else round(calculated count/sum(calculated count)*100,.1)  end) as Percentage
		from a;
quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 18 Dec 2018 02:06:03 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522093#M4356</guid>
      <dc:creator>learsaas</dc:creator>
      <dc:date>2018-12-18T02:06:03Z</dc:date>
    </item>
    <item>
      <title>Re: Sum rows and column in Proc SQL</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522094#M4357</link>
      <description>&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/192107"&gt;@learsaas&lt;/a&gt;&amp;nbsp;wrote:&lt;BR /&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql noprint;
	create table result as
		select (case when Measure1=. then 0 else Measure1 end)+
		       (case when Measure2=. then 0 else Measure2 end)+
			   (case when Measure3=. then 0 else Measure3 end) as count,
			   (case when calculated count in (.,0) then . else round(calculated count/sum(calculated count)*100,.1)  end) as Percentage
		from a;
quit;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;The SUM() function accounts for missing by&amp;nbsp;essentially considering it as 0.&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 18 Dec 2018 02:11:49 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522094#M4357</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2018-12-18T02:11:49Z</dc:date>
    </item>
    <item>
      <title>Re: Sum rows and column in Proc SQL</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522095#M4358</link>
      <description>&lt;P&gt;Are you so wide awake at this time? Kudos . I wish I had your energy.&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 18 Dec 2018 02:14:29 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522095#M4358</guid>
      <dc:creator>novinosrin</dc:creator>
      <dc:date>2018-12-18T02:14:29Z</dc:date>
    </item>
    <item>
      <title>Re: Sum rows and column in Proc SQL</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522125#M4360</link>
      <description>&lt;P&gt;Are there always exactly three measure-variables?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;If not, i would start by transposing the in source dataset to get rid of the not-that-perfect structure:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc transpose data= work.have out=work.transposed(rename=(_name_=MeasureNo col1=value));
   by id;
   var measure1 measure2 measure3;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Then you can get rid of proc sql&amp;nbsp; and use a reporting procedure like proc tabluate to generate the required output:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc tabulate data=work.transposed;
   var value;
   class id / order=unformatted missing;
   table
      id,
      value*(sum colpctsum)
   ;
run;&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, 18 Dec 2018 07:40:28 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522125#M4360</guid>
      <dc:creator>andreas_lds</dc:creator>
      <dc:date>2018-12-18T07:40:28Z</dc:date>
    </item>
    <item>
      <title>Re: Sum rows and column in Proc SQL</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522127#M4361</link>
      <description>&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/13879"&gt;@Reeza&lt;/a&gt;&amp;nbsp;wrote:&lt;BR /&gt;&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/192107"&gt;@learsaas&lt;/a&gt;&amp;nbsp;wrote:&lt;BR /&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql noprint;
	create table result as
		select (case when Measure1=. then 0 else Measure1 end)+
		       (case when Measure2=. then 0 else Measure2 end)+
			   (case when Measure3=. then 0 else Measure3 end) as count,
			   (case when calculated count in (.,0) then . else round(calculated count/sum(calculated count)*100,.1)  end) as Percentage
		from a;
quit;&lt;/CODE&gt;&lt;/PRE&gt;&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;The SUM() function accounts for missing by&amp;nbsp;essentially considering it as 0.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The SUM() function accounts for missing by&amp;nbsp;essentially considering it as 0.&amp;nbsp;？？？？？？？？？？？？？？？？？？？？？&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data _null_;
	x=sum(.);
	put x=;
run;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 18 Dec 2018 07:44:59 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522127#M4361</guid>
      <dc:creator>learsaas</dc:creator>
      <dc:date>2018-12-18T07:44:59Z</dc:date>
    </item>
    <item>
      <title>Re: Sum rows and column in Proc SQL</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522224#M4377</link>
      <description>&lt;P&gt;Thanks everyone. There are more than 3 "measure" variables so novinosrin's solution seems to be the most efficient.&lt;/P&gt;</description>
      <pubDate>Tue, 18 Dec 2018 14:14:44 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Sum-rows-and-column-in-Proc-SQL/m-p/522224#M4377</guid>
      <dc:creator>torvyle</dc:creator>
      <dc:date>2018-12-18T14:14:44Z</dc:date>
    </item>
  </channel>
</rss>

