<?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 Aggregating by a variable in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Aggregating-by-a-variable/m-p/462660#M117814</link>
    <description>&lt;P&gt;&amp;nbsp;Hi All,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I have the dataset below which gives me details of account conversions at a sub account level.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
	input account_id $ Sub_no $ reporting_date conversion_date;
	informat reporting_date conversion_date date9.;
	format reporting_date conversion_date date9.;
	
	cards;
	12345 1 31JAN2018 .
	12345 2 31JAN2018 .
	12345 3 31JAN2018 .
	67891 1 31JAN2018 .
	67891 2 31JAN2018 .
	12345 1 28FEB2018 28FEB2018
	12345 2 28FEB2018.
	12345 3 28FEB2018 .
	67891 1 28FEB2018 .
	67891 2 28FEB2018 28FEB2018
	;
run;


&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;What I need is to aggregate this data to show the below&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;STRONG&gt;Account_ID&lt;/STRONG&gt;&lt;/TD&gt;&lt;TD&gt;&lt;STRONG&gt;Reporting Date&lt;/STRONG&gt;&lt;/TD&gt;&lt;TD&gt;&lt;STRONG&gt;Conversion_Date&lt;/STRONG&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;12345&lt;/TD&gt;&lt;TD&gt;31-Jan-18&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;67891&lt;/TD&gt;&lt;TD&gt;31-Jan-18&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;12345&lt;/TD&gt;&lt;TD&gt;28-Feb-18&lt;/TD&gt;&lt;TD&gt;28-Feb-18&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;67891&lt;/TD&gt;&lt;TD&gt;28-Feb-18&lt;/TD&gt;&lt;TD&gt;28-Feb-18&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I need to view 1 record per account number and reporting date irrespective of number of sub accounts the data has been aggregated from.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Many Thanks&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Adnan&lt;/P&gt;</description>
    <pubDate>Wed, 16 May 2018 13:02:47 GMT</pubDate>
    <dc:creator>Adnan_Razaq</dc:creator>
    <dc:date>2018-05-16T13:02:47Z</dc:date>
    <item>
      <title>Aggregating by a variable</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Aggregating-by-a-variable/m-p/462660#M117814</link>
      <description>&lt;P&gt;&amp;nbsp;Hi All,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I have the dataset below which gives me details of account conversions at a sub account level.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
	input account_id $ Sub_no $ reporting_date conversion_date;
	informat reporting_date conversion_date date9.;
	format reporting_date conversion_date date9.;
	
	cards;
	12345 1 31JAN2018 .
	12345 2 31JAN2018 .
	12345 3 31JAN2018 .
	67891 1 31JAN2018 .
	67891 2 31JAN2018 .
	12345 1 28FEB2018 28FEB2018
	12345 2 28FEB2018.
	12345 3 28FEB2018 .
	67891 1 28FEB2018 .
	67891 2 28FEB2018 28FEB2018
	;
run;


&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;What I need is to aggregate this data to show the below&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;STRONG&gt;Account_ID&lt;/STRONG&gt;&lt;/TD&gt;&lt;TD&gt;&lt;STRONG&gt;Reporting Date&lt;/STRONG&gt;&lt;/TD&gt;&lt;TD&gt;&lt;STRONG&gt;Conversion_Date&lt;/STRONG&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;12345&lt;/TD&gt;&lt;TD&gt;31-Jan-18&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;67891&lt;/TD&gt;&lt;TD&gt;31-Jan-18&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;12345&lt;/TD&gt;&lt;TD&gt;28-Feb-18&lt;/TD&gt;&lt;TD&gt;28-Feb-18&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;67891&lt;/TD&gt;&lt;TD&gt;28-Feb-18&lt;/TD&gt;&lt;TD&gt;28-Feb-18&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I need to view 1 record per account number and reporting date irrespective of number of sub accounts the data has been aggregated from.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Many Thanks&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Adnan&lt;/P&gt;</description>
      <pubDate>Wed, 16 May 2018 13:02:47 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Aggregating-by-a-variable/m-p/462660#M117814</guid>
      <dc:creator>Adnan_Razaq</dc:creator>
      <dc:date>2018-05-16T13:02:47Z</dc:date>
    </item>
    <item>
      <title>Re: Aggregating by a variable</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Aggregating-by-a-variable/m-p/462666#M117818</link>
      <description>&lt;P&gt;PROC SUMMARY will do this&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;UNTESTED CODE&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc summary data=have;
    class account_id;
    var reporting_date conversion_date;
    output out=want min=;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Wed, 16 May 2018 13:08:22 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Aggregating-by-a-variable/m-p/462666#M117818</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2018-05-16T13:08:22Z</dc:date>
    </item>
    <item>
      <title>Re: Aggregating by a variable</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Aggregating-by-a-variable/m-p/462668#M117819</link>
      <description>&lt;P&gt;Two approaches, SQL and data step, that produce the same result:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input account_id $ Sub_no $ reporting_date conversion_date;
informat reporting_date conversion_date date9.;
format reporting_date conversion_date date9.;
cards;
12345 1 31JAN2018 .
12345 2 31JAN2018 .
12345 3 31JAN2018 .
67891 1 31JAN2018 .
67891 2 31JAN2018 .
12345 1 28FEB2018 28FEB2018
12345 2 28FEB2018.
12345 3 28FEB2018 .
67891 1 28FEB2018 .
67891 2 28FEB2018 28FEB2018
;
run;

proc sql;
create table want1 as
select account_id, reporting_date, max(conversion_date) as conversion_date format=date9.
from have
group by reporting_date, account_id;
quit;

data want2;
set have (rename=(conversion_date=_cvdate));
by reporting_date account_id;
retain conversion_date;
format conversion_date date9.;
if _cvdate ne . then conversion_date = _cvdate;
if last.account_id then output;
drop _cvdate sub_no;
run;

&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Wed, 16 May 2018 13:15:12 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Aggregating-by-a-variable/m-p/462668#M117819</guid>
      <dc:creator>Kurt_Bremser</dc:creator>
      <dc:date>2018-05-16T13:15:12Z</dc:date>
    </item>
  </channel>
</rss>

