<?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 How to compute percentage for multiple binary variables by groups? in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/How-to-compute-percentage-for-multiple-binary-variables-by/m-p/835511#M330314</link>
    <description>&lt;P&gt;Hi, I have a data pretty much like below:&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;Type&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Year&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;A&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;B&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;C&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;And I want to compute the percentage for A, B, C by each group Type and Year, the result is pretty much like below:&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;Type&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Year&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;A percent&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;B percent&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;C percent&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;100%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;100%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;100%&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;Do you know how to do it? When I used the below code, the result was different from what I expected, it had lots of years for each type.&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=""&gt;proc sql;
	create table rate as
	select type, year, A, B, C, sum(A)/count(A) as pctA,
		sum(B)/count(B) as pctB, sum(C)/count(C) as pctC
	from (select type, year, A, B, C from one group by type, year)
group by type, year;
quit;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;Could anyone help me with it? Thank you!&lt;/P&gt;</description>
    <pubDate>Tue, 27 Sep 2022 22:09:52 GMT</pubDate>
    <dc:creator>SAS-questioner</dc:creator>
    <dc:date>2022-09-27T22:09:52Z</dc:date>
    <item>
      <title>How to compute percentage for multiple binary variables by groups?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-compute-percentage-for-multiple-binary-variables-by/m-p/835511#M330314</link>
      <description>&lt;P&gt;Hi, I have a data pretty much like below:&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;Type&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Year&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;A&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;B&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;C&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;And I want to compute the percentage for A, B, C by each group Type and Year, the result is pretty much like below:&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;Type&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Year&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;A percent&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;B percent&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;C percent&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;100%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2011&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;0%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2012&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;100%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50%&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;100%&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;Do you know how to do it? When I used the below code, the result was different from what I expected, it had lots of years for each type.&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=""&gt;proc sql;
	create table rate as
	select type, year, A, B, C, sum(A)/count(A) as pctA,
		sum(B)/count(B) as pctB, sum(C)/count(C) as pctC
	from (select type, year, A, B, C from one group by type, year)
group by type, year;
quit;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;Could anyone help me with it? Thank you!&lt;/P&gt;</description>
      <pubDate>Tue, 27 Sep 2022 22:09:52 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-compute-percentage-for-multiple-binary-variables-by/m-p/835511#M330314</guid>
      <dc:creator>SAS-questioner</dc:creator>
      <dc:date>2022-09-27T22:09:52Z</dc:date>
    </item>
    <item>
      <title>Re: How to compute percentage for multiple binary variables by groups?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-compute-percentage-for-multiple-binary-variables-by/m-p/835513#M330315</link>
      <description>&lt;P&gt;Proc means is probably more efficient.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;For binary values, the mean is equivalent to the percentage mathematically.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;The SQL doesn't work because A, B, C are included in the SELECT statement. The log should have a message indicating that this means it's merging the table with the summary rather than just having the summary data. The SQL is also redundant, the subquery isn't required at all.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt; 1          OPTIONS NONOTES NOSTIMER NOSOURCE NOSYNTAXCHECK;
 68         
 69         proc sql;
 70         create table rate as
 71         select type, year, A, B, C, sum(A)/count(A) as pctA,
 72         sum(B)/count(B) as pctB, sum(C)/count(C) as pctC
 73         from (select type, year, A, B, C from have group by type, year)
 74         group by type, year;
 NOTE: A GROUP BY clause has been discarded because neither the SELECT clause nor the optional HAVING clause of the associated 
       table-expression referenced a summary function.
&lt;FONT color="#FF0000"&gt;&lt;STRONG&gt; NOTE: The query requires remerging summary statistics back with the original data.&lt;/STRONG&gt;&lt;/FONT&gt;
 NOTE: Table WORK.RATE created, with 8 rows and 8 columns.&lt;/PRE&gt;
&lt;P&gt;Here are two ways to do this, noting that proc means will scale much easier if you have a lot of variables.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc means data=have MEAN NWAY;
class type year;
var a b c;
output out=want mean= /autoname;
run;

proc print data=want noobs;
format a_mean b_mean c_mean percent12.1;
run;

proc sql;
	create table rate as
	select type, year, sum(A)/count(A) as pctA,
		sum(B)/count(B) as pctB, sum(C)/count(C) as pctC
	from have
group by type, year;
quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 27 Sep 2022 22:24:00 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-compute-percentage-for-multiple-binary-variables-by/m-p/835513#M330315</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2022-09-27T22:24:00Z</dc:date>
    </item>
  </channel>
</rss>

