<?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: Count distinct values in proc summary/means in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/811288#M319976</link>
    <description>&lt;P&gt;The solution put together by&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/4954"&gt;@Astounding&lt;/a&gt;&amp;nbsp;and&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/11562"&gt;@Kurt_Bremser&lt;/a&gt;&amp;nbsp;ended up working nicely in my situation. I wanted to use proc means to count distinct values because I am utilizing the types statement to get a variety of summary rows, which wouldn't work as easily in other procedures. My implementation looked something like this:&lt;/P&gt;&lt;LI-CODE lang="sas"&gt;proc means data=input_data noprint;
  class category subcategory subject;
  types category*subcategory*subject category*subject subject;
  output out=data1(rename=_type_=type) n=n;
run;

proc means data=data1 noprint nway missing;
  class category subcategory type;
  var n;
  output out=data2(drop=_:) n=n sum=sum;
run;&lt;/LI-CODE&gt;&lt;P&gt;In fact, with that method, I was able to to get both a count of distinct subjects (the n column in data2) and a count of all rows (the sum column in data2).&lt;/P&gt;</description>
    <pubDate>Tue, 03 May 2022 17:20:55 GMT</pubDate>
    <dc:creator>mtnbikerjoshua</dc:creator>
    <dc:date>2022-05-03T17:20:55Z</dc:date>
    <item>
      <title>Count distinct values in proc summary/means</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392106#M94284</link>
      <description>&lt;P&gt;Hi I would be gratefull if anyone could tell me if is there posibility for counting distinct values in&amp;nbsp; summary or means procedure?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I know that I can do that by proc sql, however for c&lt;SPAN class="short_text"&gt;&lt;SPAN class=""&gt;ohesion of my code I would prefere use proc summary or means.&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thank you.&lt;/P&gt;</description>
      <pubDate>Thu, 31 Aug 2017 06:17:32 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392106#M94284</guid>
      <dc:creator>Matt3</dc:creator>
      <dc:date>2017-08-31T06:17:32Z</dc:date>
    </item>
    <item>
      <title>Re: Count distinct values in proc summary/means</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392119#M94292</link>
      <description>&lt;P&gt;SUMMARY or MEANS alone don't do that, but a combination with PROC FREQ can do it:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc freq data=sashelp.class noprint;
table sex / out=class;
run;

proc summary data=class n;
output out=want (drop=_type_);
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 31 Aug 2017 08:00:52 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392119#M94292</guid>
      <dc:creator>Kurt_Bremser</dc:creator>
      <dc:date>2017-08-31T08:00:52Z</dc:date>
    </item>
    <item>
      <title>Re: Count distinct values in proc summary/means</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392120#M94293</link>
      <description>&lt;P&gt;Yes and no. &amp;nbsp;SUMMARY/MEANS isn't built for that, so you have to jump through a hoop or two. &amp;nbsp;For example, suppose you want to know how many DISTINCT STATE values appear in your data set:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;proc summary data=have nway;&lt;/P&gt;
&lt;P&gt;class state;&lt;/P&gt;
&lt;P&gt;var some_numeric_variable;&lt;/P&gt;
&lt;P&gt;output out=stats (keep=state _freq_) n=;&lt;/P&gt;
&lt;P&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Now the number of observations in STATS is the number of STATE values that appeared in the original data set HAVE. &amp;nbsp;So it takes a little extra processing to capture that number, such as:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data _null_;&lt;/P&gt;
&lt;P&gt;set stats nobs=n_states;&lt;/P&gt;
&lt;P&gt;put n_states=;&lt;/P&gt;
&lt;P&gt;stop;&lt;/P&gt;
&lt;P&gt;run;&lt;/P&gt;</description>
      <pubDate>Thu, 31 Aug 2017 08:03:17 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392120#M94293</guid>
      <dc:creator>Astounding</dc:creator>
      <dc:date>2017-08-31T08:03:17Z</dc:date>
    </item>
    <item>
      <title>Re: Count distinct values in proc summary/means</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392123#M94295</link>
      <description>&lt;P&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/4954"&gt;@Astounding&lt;/a&gt;'s answer reveals a solution with two PROC SUMMARY steps:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc summary data=sashelp.class nway;
class sex;
var age; * just some numeric variable for syntactical completeness;
output out=class (keep=sex _freq_) n=;
run;

proc summary data=class n;
output out=want (drop=_type_);
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Thu, 31 Aug 2017 08:13:45 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392123#M94295</guid>
      <dc:creator>Kurt_Bremser</dc:creator>
      <dc:date>2017-08-31T08:13:45Z</dc:date>
    </item>
    <item>
      <title>Re: Count distinct values in proc summary/means</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392124#M94296</link>
      <description>&lt;P&gt;You can use proc means and proc summary, if you have a numeric variable in your data set or create a numeric variable for that purpose.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;Data A;
  Do ID = 'A', 'B', 'T', 'Z';
    Do NumVar = 1 To Ceil(Ranuni(1)*10);
	  Output;
	End;
  End;
Run;

Proc Means Data=A NoPrint;
  By ID;
  Var NumVar; 
  Output Out=Want (Keep=ID _FREQ_) N=; * remove _FREQ_ if not required;
Run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Thu, 31 Aug 2017 08:32:20 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392124#M94296</guid>
      <dc:creator>user24feb</dc:creator>
      <dc:date>2017-08-31T08:32:20Z</dc:date>
    </item>
    <item>
      <title>Re: Count distinct values in proc summary/means</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392172#M94329</link>
      <description>&lt;P&gt;PROC FREQ can do that.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;ods select none;
ods output nlevels=want;
proc freq data=sashelp.class nlevels;
table _all_;
run;
ods select all;

proc print;run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Thu, 31 Aug 2017 12:40:48 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392172#M94329</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2017-08-31T12:40:48Z</dc:date>
    </item>
    <item>
      <title>Re: Count distinct values in proc summary/means</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392294#M94370</link>
      <description>&lt;P&gt;I `m sorry I was not very clear, I need something like this&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;proc summary data=have missing;&lt;/P&gt;&lt;P&gt;class id1 id2 data;&lt;/P&gt;&lt;P&gt;var var1 var2 var3;&lt;/P&gt;&lt;P&gt;types id1*id2*id3;&lt;/P&gt;&lt;P&gt;output out=wan sum(var1)= max(var2) n(&lt;FONT color="#FF0000"&gt;DISTINCT&lt;/FONT&gt; var3)=;/&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;of course this way is not possible&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am able to do that, with two separate procedures and then merging result datasets, however, I was curious if it`s possible with one procedure or dataset just to make my code&amp;nbsp;&lt;SPAN class="short_text"&gt;&lt;SPAN class=""&gt;clearer&lt;/SPAN&gt;&lt;/SPAN&gt;.&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 31 Aug 2017 17:10:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392294#M94370</guid>
      <dc:creator>Matt3</dc:creator>
      <dc:date>2017-08-31T17:10:19Z</dc:date>
    </item>
    <item>
      <title>Re: Count distinct values in proc summary/means</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392313#M94376</link>
      <description>&lt;P&gt;Provide a small example data set and what the result should be.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I am not even sure we are all using "distinct" in the same way.&lt;/P&gt;</description>
      <pubDate>Thu, 31 Aug 2017 18:20:48 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392313#M94376</guid>
      <dc:creator>ballardw</dc:creator>
      <dc:date>2017-08-31T18:20:48Z</dc:date>
    </item>
    <item>
      <title>Re: Count distinct values in proc summary/means</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392346#M94386</link>
      <description>&lt;P&gt;You can do what I want in proc sql:&lt;BR /&gt;proc sql;&lt;BR /&gt;create table want as&lt;BR /&gt;select id1, id2, date sum(var1), max(var2), count(distinct (var3)) from have;&lt;BR /&gt;quit;&lt;BR /&gt;&lt;BR /&gt;I would like to know if there is option in proc summary/means for do the same.&lt;/P&gt;</description>
      <pubDate>Thu, 31 Aug 2017 19:51:32 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/392346#M94386</guid>
      <dc:creator>Matt3</dc:creator>
      <dc:date>2017-08-31T19:51:32Z</dc:date>
    </item>
    <item>
      <title>Re: Count distinct values in proc summary/means</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/811288#M319976</link>
      <description>&lt;P&gt;The solution put together by&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/4954"&gt;@Astounding&lt;/a&gt;&amp;nbsp;and&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/11562"&gt;@Kurt_Bremser&lt;/a&gt;&amp;nbsp;ended up working nicely in my situation. I wanted to use proc means to count distinct values because I am utilizing the types statement to get a variety of summary rows, which wouldn't work as easily in other procedures. My implementation looked something like this:&lt;/P&gt;&lt;LI-CODE lang="sas"&gt;proc means data=input_data noprint;
  class category subcategory subject;
  types category*subcategory*subject category*subject subject;
  output out=data1(rename=_type_=type) n=n;
run;

proc means data=data1 noprint nway missing;
  class category subcategory type;
  var n;
  output out=data2(drop=_:) n=n sum=sum;
run;&lt;/LI-CODE&gt;&lt;P&gt;In fact, with that method, I was able to to get both a count of distinct subjects (the n column in data2) and a count of all rows (the sum column in data2).&lt;/P&gt;</description>
      <pubDate>Tue, 03 May 2022 17:20:55 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Count-distinct-values-in-proc-summary-means/m-p/811288#M319976</guid>
      <dc:creator>mtnbikerjoshua</dc:creator>
      <dc:date>2022-05-03T17:20:55Z</dc:date>
    </item>
  </channel>
</rss>

