<?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: Summarizing Multiple categorical response from multiple column in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Summarizing-Multiple-categorical-response-from-multiple-column/m-p/736768#M229595</link>
    <description>&lt;P&gt;From where do you get those counts? response 2 has only three values, and response 3 just two.&lt;/P&gt;</description>
    <pubDate>Sat, 24 Apr 2021 19:11:34 GMT</pubDate>
    <dc:creator>Kurt_Bremser</dc:creator>
    <dc:date>2021-04-24T19:11:34Z</dc:date>
    <item>
      <title>Summarizing Multiple categorical response from multiple column</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Summarizing-Multiple-categorical-response-from-multiple-column/m-p/736766#M229593</link>
      <description>&lt;P&gt;Hello Dear Friends,&lt;/P&gt;&lt;P&gt;Could you pls help me counting number and % (Response and or Case) of multiple response from multiple columns. % Response and %cases can in be either in separate table or same table with number count column&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Data have;&lt;/P&gt;&lt;P&gt;ID&amp;nbsp; Gender resp_1 resp_2 resp_3 resp_4&lt;BR /&gt;1&amp;nbsp; &amp;nbsp; M&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;3&lt;BR /&gt;2&amp;nbsp; &amp;nbsp; F&amp;nbsp; &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;&lt;BR /&gt;3&amp;nbsp; &amp;nbsp; M&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 3&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;4&lt;BR /&gt;4&amp;nbsp; &amp;nbsp; F&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 3&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;5&amp;nbsp; &amp;nbsp; M&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;&lt;BR /&gt;6&amp;nbsp; &amp;nbsp; M&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 3&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Output want:&amp;nbsp;&lt;/P&gt;&lt;P&gt;Respse&amp;nbsp; N&amp;nbsp; Response (%)&amp;nbsp; Case (%)&lt;BR /&gt;1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;3&amp;nbsp; &amp;nbsp; &amp;nbsp;25.0&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;50.0&lt;BR /&gt;2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;4&amp;nbsp; &amp;nbsp; &amp;nbsp; 33.3&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;66.7&lt;BR /&gt;3&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 4&amp;nbsp; &amp;nbsp; &amp;nbsp; 33.3&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 66.7&lt;BR /&gt;4&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;8.3&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;16.7&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I really appreciate your support.&lt;/P&gt;&lt;P&gt;Thanks in advance.&lt;/P&gt;&lt;P&gt;Regards, Akter&lt;/P&gt;</description>
      <pubDate>Sat, 24 Apr 2021 18:55:22 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Summarizing-Multiple-categorical-response-from-multiple-column/m-p/736766#M229593</guid>
      <dc:creator>Akter</dc:creator>
      <dc:date>2021-04-24T18:55:22Z</dc:date>
    </item>
    <item>
      <title>Re: Summarizing Multiple categorical response from multiple column</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Summarizing-Multiple-categorical-response-from-multiple-column/m-p/736768#M229595</link>
      <description>&lt;P&gt;From where do you get those counts? response 2 has only three values, and response 3 just two.&lt;/P&gt;</description>
      <pubDate>Sat, 24 Apr 2021 19:11:34 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Summarizing-Multiple-categorical-response-from-multiple-column/m-p/736768#M229595</guid>
      <dc:creator>Kurt_Bremser</dc:creator>
      <dc:date>2021-04-24T19:11:34Z</dc:date>
    </item>
    <item>
      <title>Re: Summarizing Multiple categorical response from multiple column</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Summarizing-Multiple-categorical-response-from-multiple-column/m-p/736804#M229610</link>
      <description>Sorry for the confusion.&lt;BR /&gt;1, 2, 3 and 4 are different categorical values of the variables (column) Resp_1, Resp_2, Resp_3 and Resp_4. Resp_1, Resp_2, Resp_3 and Resp_4 are multiple response. I.e. The subject ID 1 responded multiple responses such as 1, 2 and 3 and subject ID 2 responded only 1 which is 2 in column Resp_1.&lt;BR /&gt;You can think of column value 1=orange, 2=Apple, 3=Graphs, 4=Blackberry. Each subject ID can make max 4 responses, which are written in 4 columns as Resp_1, Resp_2, Resp_3 and Resp_4. I would like to calculate how many respondents preferred 1=orange, 2=Apple, 3=Graphs, 4=Blackberry.</description>
      <pubDate>Sun, 25 Apr 2021 02:25:45 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Summarizing-Multiple-categorical-response-from-multiple-column/m-p/736804#M229610</guid>
      <dc:creator>Akter</dc:creator>
      <dc:date>2021-04-25T02:25:45Z</dc:date>
    </item>
    <item>
      <title>Re: Summarizing Multiple categorical response from multiple column</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Summarizing-Multiple-categorical-response-from-multiple-column/m-p/736805#M229611</link>
      <description>&lt;P&gt;Transpose your wide data to a long structure. This makes it much easier to then use SAS procs like Freq, Report, Means, Tabulate, SQL.... for what you're after.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
  infile datalines truncover;
  input (ID Gender resp_1 resp_2 resp_3 resp_4) ($);
  datalines;
1 M 1 2 3
2 F 2 
3 M 1 2 3 4
4 F 3 
5 M 2 
6 M 1 3 
;

proc transpose 
    data=have 
    out =have_long(drop=_name_ rename=(col1=response) where=(not missing(response)) ) 
    ;
   by id gender;
   var resp_:;
run;
&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;And as a side note: Posting fully working SAS data step code to create the have table would be highly appreciated.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Sun, 25 Apr 2021 02:45:23 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Summarizing-Multiple-categorical-response-from-multiple-column/m-p/736805#M229611</guid>
      <dc:creator>Patrick</dc:creator>
      <dc:date>2021-04-25T02:45:23Z</dc:date>
    </item>
    <item>
      <title>Re: Summarizing Multiple categorical response from multiple column</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Summarizing-Multiple-categorical-response-from-multiple-column/m-p/736836#M229631</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;Data have;
infile cards truncover;
input ID  Gender $  resp_1 resp_2 resp_3 resp_4;
cards;
1    M            1          2         3
2    F             2                    
3    M            1          2          3             4
4    F            3                      
5    M           2          
6    M           1          3 
;

data temp;
 set have;
 array x{*} resp_:;
 do i=1 to dim(x);
   if not missing(x{i}) then do;value=x{i};output;end;
 end;
 drop i resp_:;
run;

proc sql;
create table want as
select value as resp,count(distinct id) as n ,
calculated n/(select count(*) from temp) as per1 label='Response(%)' format=percent8.2,
calculated n/(select count(distinct id) from temp) as per2 label='Case(%)' format=percent8.2
 from temp 
  group by value;
quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Sun, 25 Apr 2021 12:30:04 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Summarizing-Multiple-categorical-response-from-multiple-column/m-p/736836#M229631</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2021-04-25T12:30:04Z</dc:date>
    </item>
  </channel>
</rss>

