<?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: Transpose using SAS array in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Transpose-using-SAS-array/m-p/416357#M102212</link>
    <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input Id	Value	date $;
cards;
11	110	1-Jan-17
11	101	31-Jan-17
11	120	3-Feb-17
12	200	3-Feb-17
12	210	9-Feb-17
13	222	1-Jul-17
;
run;
proc sql;
select max(n) into : n
 from (select count(*) as n from have group by id);
quit;

proc summary data=have;
by id;
output out=want idgroup(out[&amp;amp;n] (value date)=);
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Mon, 27 Nov 2017 12:44:00 GMT</pubDate>
    <dc:creator>Ksharp</dc:creator>
    <dc:date>2017-11-27T12:44:00Z</dc:date>
    <item>
      <title>Transpose using SAS array</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Transpose-using-SAS-array/m-p/416342#M102207</link>
      <description>&lt;P&gt;Hi,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I have valuation on different dates for given Id's. I want to have in output first two valuation by chronological order.&lt;/P&gt;&lt;P&gt;I used array but want to handle dimension dynamically. Also retain statement giving incorrect values for id having less no of rows.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Input:&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Id&lt;/TD&gt;&lt;TD&gt;Value&lt;/TD&gt;&lt;TD&gt;date&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;11&lt;/TD&gt;&lt;TD&gt;110&lt;/TD&gt;&lt;TD&gt;1-Jan-17&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;11&lt;/TD&gt;&lt;TD&gt;101&lt;/TD&gt;&lt;TD&gt;31-Jan-17&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;11&lt;/TD&gt;&lt;TD&gt;120&lt;/TD&gt;&lt;TD&gt;3-Feb-17&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;200&lt;/TD&gt;&lt;TD&gt;3-Feb-17&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;210&lt;/TD&gt;&lt;TD&gt;9-Feb-17&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;13&lt;/TD&gt;&lt;TD&gt;222&lt;/TD&gt;&lt;TD&gt;1-Jul-17&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;&lt;P&gt;Output:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Id&lt;/TD&gt;&lt;TD&gt;date1&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;Value1&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;date2&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;value2&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;11&lt;/TD&gt;&lt;TD&gt;1-Jan-17&lt;/TD&gt;&lt;TD&gt;110&lt;/TD&gt;&lt;TD&gt;31-Jan-17&lt;/TD&gt;&lt;TD&gt;101&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;3-Feb-17&lt;/TD&gt;&lt;TD&gt;200&lt;/TD&gt;&lt;TD&gt;9-Feb-17&lt;/TD&gt;&lt;TD&gt;210&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;13&lt;/TD&gt;&lt;TD&gt;1-Jul-17&lt;/TD&gt;&lt;TD&gt;222&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;code:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;data t1;&lt;BR /&gt;input ID DATE VAL;&lt;BR /&gt;INFORMAT DATE DATE9.;&lt;BR /&gt;FORMAT DATE DATE9.;&lt;BR /&gt;DATALINES;&lt;BR /&gt;11 01JAN2017 101&lt;BR /&gt;11 31JAN2017 110&lt;BR /&gt;11 03FEB2017 230&lt;BR /&gt;12 03FEB2017 112&lt;BR /&gt;12 09FEB2017 114&lt;BR /&gt;13 01JUL2017 123&lt;BR /&gt;RUN;&lt;/P&gt;&lt;P&gt;PROC SORT DATA=T1;&lt;BR /&gt;BY ID DATE;&lt;BR /&gt;RUN;&lt;/P&gt;&lt;P&gt;data t2;&lt;BR /&gt;set t1;&lt;BR /&gt;by id;&lt;BR /&gt;/*retain m1 m2;*/&lt;BR /&gt;array amtt[*] amt1-amt3;&lt;BR /&gt;array datet[*] date1-date3;&lt;/P&gt;&lt;P&gt;if first.id then do;&lt;BR /&gt;i=0;&lt;BR /&gt;amtt[1]=VAL;&lt;BR /&gt;datet[1]=date;&lt;BR /&gt;end;&lt;BR /&gt;i+1;&lt;BR /&gt;amtt[i]=VAL;&lt;BR /&gt;datet[i]=date;&lt;BR /&gt;if last.id;&lt;BR /&gt;retain amt1 amt2 amt3 date1 date2 date3;&lt;BR /&gt;run;&lt;/P&gt;</description>
      <pubDate>Mon, 27 Nov 2017 11:51:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Transpose-using-SAS-array/m-p/416342#M102207</guid>
      <dc:creator>PRAVIN_JAIN</dc:creator>
      <dc:date>2017-11-27T11:51:19Z</dc:date>
    </item>
    <item>
      <title>Re: Transpose using SAS array</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Transpose-using-SAS-array/m-p/416357#M102212</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input Id	Value	date $;
cards;
11	110	1-Jan-17
11	101	31-Jan-17
11	120	3-Feb-17
12	200	3-Feb-17
12	210	9-Feb-17
13	222	1-Jul-17
;
run;
proc sql;
select max(n) into : n
 from (select count(*) as n from have group by id);
quit;

proc summary data=have;
by id;
output out=want idgroup(out[&amp;amp;n] (value date)=);
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 27 Nov 2017 12:44:00 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Transpose-using-SAS-array/m-p/416357#M102212</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2017-11-27T12:44:00Z</dc:date>
    </item>
    <item>
      <title>Re: Transpose using SAS array</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Transpose-using-SAS-array/m-p/416424#M102240</link>
      <description>&lt;P&gt;What is supposed to be dynamic about this?&amp;nbsp; The number of elements you decide to keep?&amp;nbsp; If that's the case, here's a way.&amp;nbsp; Assuming you have already read in the data and sorted by ID DATE:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;%let n=2;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data want;&lt;/P&gt;
&lt;P&gt;set have;&lt;/P&gt;
&lt;P&gt;by id;&lt;/P&gt;
&lt;P&gt;retain date1-date&amp;amp;n value1-value&amp;amp;n;&lt;/P&gt;
&lt;P&gt;array dates {&amp;amp;n} date1-date&amp;amp;n;&lt;/P&gt;
&lt;P&gt;array values {&amp;amp;n} value1-value&amp;amp;n;&lt;/P&gt;
&lt;P&gt;if first.id then do _n_=1 to &amp;amp;n;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&amp;nbsp; dates{_n_} = .;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&amp;nbsp; values{_n_}=.;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&amp;nbsp; recnum = 0;&lt;/P&gt;
&lt;P&gt;end;&lt;/P&gt;
&lt;P&gt;recnum + 1;&lt;/P&gt;
&lt;P&gt;if recnum &amp;lt;= &amp;amp;n then do;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&amp;nbsp; dates{recnum} = date;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&amp;nbsp; values{recnum} = value;&lt;/P&gt;
&lt;P&gt;end;&lt;/P&gt;
&lt;P&gt;if last.id;&lt;/P&gt;
&lt;P&gt;keep id date1-date&amp;amp;n value1-value&amp;amp;n;&lt;/P&gt;
&lt;P&gt;format date: date9.;&lt;/P&gt;
&lt;P&gt;run;&lt;/P&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;</description>
      <pubDate>Mon, 27 Nov 2017 15:13:08 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Transpose-using-SAS-array/m-p/416424#M102240</guid>
      <dc:creator>Astounding</dc:creator>
      <dc:date>2017-11-27T15:13:08Z</dc:date>
    </item>
  </channel>
</rss>

