<?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 count distinct values across columns in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/How-to-count-distinct-values-across-columns/m-p/911984#M359572</link>
    <description>&lt;P&gt;I have a wide dataset, and each subject_id has variables for 2015-2020.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;For the zip code variable, for example, I want to know how many different values&amp;nbsp; are recorded for each subject across the 5 columns of zip code data (ideally not counting missing data).&amp;nbsp;I'm sure SAS SQL could do this , but I'm struggling to figure what the operation would be called.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Below is an example of what an excerpt of my data looks like, and the zip_count variable is what I'm hoping to calculate.&amp;nbsp;&lt;/P&gt;
&lt;TABLE width="543"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="95"&gt;subject_id&lt;/TD&gt;
&lt;TD width="64"&gt;zip_15&lt;/TD&gt;
&lt;TD width="64"&gt;zip_16&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;zip_17&lt;/TD&gt;
&lt;TD width="64"&gt;zip_18&lt;/TD&gt;
&lt;TD width="64"&gt;zip_19&lt;/TD&gt;
&lt;TD width="64"&gt;zip_20&lt;/TD&gt;
&lt;TD width="64"&gt;zip_count&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;a&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;b&lt;/TD&gt;
&lt;TD&gt;.&lt;/TD&gt;
&lt;TD&gt;.&lt;/TD&gt;
&lt;TD&gt;.&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;c&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;44444&lt;/TD&gt;
&lt;TD&gt;44444&lt;/TD&gt;
&lt;TD&gt;44444&lt;/TD&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;d&lt;/TD&gt;
&lt;TD&gt;.&lt;/TD&gt;
&lt;TD&gt;.&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;44444&lt;/TD&gt;
&lt;TD&gt;44444&lt;/TD&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Thu, 18 Jan 2024 16:43:36 GMT</pubDate>
    <dc:creator>greesamu</dc:creator>
    <dc:date>2024-01-18T16:43:36Z</dc:date>
    <item>
      <title>How to count distinct values across columns</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-count-distinct-values-across-columns/m-p/911984#M359572</link>
      <description>&lt;P&gt;I have a wide dataset, and each subject_id has variables for 2015-2020.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;For the zip code variable, for example, I want to know how many different values&amp;nbsp; are recorded for each subject across the 5 columns of zip code data (ideally not counting missing data).&amp;nbsp;I'm sure SAS SQL could do this , but I'm struggling to figure what the operation would be called.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Below is an example of what an excerpt of my data looks like, and the zip_count variable is what I'm hoping to calculate.&amp;nbsp;&lt;/P&gt;
&lt;TABLE width="543"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="95"&gt;subject_id&lt;/TD&gt;
&lt;TD width="64"&gt;zip_15&lt;/TD&gt;
&lt;TD width="64"&gt;zip_16&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;zip_17&lt;/TD&gt;
&lt;TD width="64"&gt;zip_18&lt;/TD&gt;
&lt;TD width="64"&gt;zip_19&lt;/TD&gt;
&lt;TD width="64"&gt;zip_20&lt;/TD&gt;
&lt;TD width="64"&gt;zip_count&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;a&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;b&lt;/TD&gt;
&lt;TD&gt;.&lt;/TD&gt;
&lt;TD&gt;.&lt;/TD&gt;
&lt;TD&gt;.&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;c&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;44444&lt;/TD&gt;
&lt;TD&gt;44444&lt;/TD&gt;
&lt;TD&gt;44444&lt;/TD&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;d&lt;/TD&gt;
&lt;TD&gt;.&lt;/TD&gt;
&lt;TD&gt;.&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;55555&lt;/TD&gt;
&lt;TD&gt;44444&lt;/TD&gt;
&lt;TD&gt;44444&lt;/TD&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 18 Jan 2024 16:43:36 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-count-distinct-values-across-columns/m-p/911984#M359572</guid>
      <dc:creator>greesamu</dc:creator>
      <dc:date>2024-01-18T16:43:36Z</dc:date>
    </item>
    <item>
      <title>Re: How to count distinct values across columns</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-count-distinct-values-across-columns/m-p/911985#M359573</link>
      <description>&lt;P&gt;/* UNTESTED CODE */&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
    set have;
    array z zip_15-zip_20;
    call sortn(of z(*));
    zip_count=0;
    do i=2 to dim(z);
        if not missing(z(i-1)) then zip_count=1;
        if z(i)^z(i-1) then zip_count=zip_count+1;
    end;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;If you want tested code, please provide data as working SAS data step code (&lt;A href="https://blogs.sas.com/content/sastraining/2016/03/11/jedi-sas-tricks-data-to-data-step-macro/" target="_self"&gt;examples and instructions&lt;/A&gt;), and not as a screen capture and not as Excel.&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 18 Jan 2024 16:54:58 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-count-distinct-values-across-columns/m-p/911985#M359573</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2024-01-18T16:54:58Z</dc:date>
    </item>
    <item>
      <title>Re: How to count distinct values across columns</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-count-distinct-values-across-columns/m-p/911991#M359578</link>
      <description>&lt;P&gt;Correction&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
    set have;
    array z zip_15-zip_20;
    call sortn(of z(*));
    zip_count=1;
    do i=2 to dim(z);
        if z(i)^=z(i-1) and missing(z(i-1)) then zip_count=1;
        else if z(i)^=z(i-1) and not missing(z(i-1)) then zip_count=zip_count+1;
    end;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Thu, 18 Jan 2024 17:14:29 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-count-distinct-values-across-columns/m-p/911991#M359578</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2024-01-18T17:14:29Z</dc:date>
    </item>
  </channel>
</rss>

