<?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: Retain + Looping among multiple row record in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Retain-Looping-among-multiple-row-record/m-p/740165#M231148</link>
    <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
  input Study_ID	Month	Score;
datalines;
812	0	56
812	12	37
812	24	36
812	36	35
812	48	34
812	60	33
813	0	61
813	3	51
813	12	50
813	24	49
813	36	48
815	0	47
815	3	43
815	12	42
815	24	41
815	48	39
;
proc transpose data=have out=temp(drop=_name_) prefix=score_;
by study_id;
var month score;
id month;
run;
proc sql noprint;
select cats('score_',month) into :list separated by ' ' from have order by month;
quit;
data want;
retain Study_ID	Month	Score &amp;amp;list ;
 merge have temp;
 by study_id;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Mon, 10 May 2021 12:53:50 GMT</pubDate>
    <dc:creator>Ksharp</dc:creator>
    <dc:date>2021-05-10T12:53:50Z</dc:date>
    <item>
      <title>Retain + Looping among multiple row record</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Retain-Looping-among-multiple-row-record/m-p/740056#M231106</link>
      <description>&lt;P&gt;Hi there, I am trying to take a score recorded at each time interval for a subject and add columns with that score. For example I want to turn a table like this:&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Study_ID&lt;/TD&gt;&lt;TD&gt;Month&lt;/TD&gt;&lt;TD&gt;Score&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;56&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;24&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;60&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;24&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;24&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Into a table like this&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Study_ID&lt;/TD&gt;&lt;TD&gt;Month&lt;/TD&gt;&lt;TD&gt;Score&lt;/TD&gt;&lt;TD&gt;Score0&lt;/TD&gt;&lt;TD&gt;Score3&lt;/TD&gt;&lt;TD&gt;Score12&lt;/TD&gt;&lt;TD&gt;Score24&lt;/TD&gt;&lt;TD&gt;Score36&lt;/TD&gt;&lt;TD&gt;Score48&lt;/TD&gt;&lt;TD&gt;Score60&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;56&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;24&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;60&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;24&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;24&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;39&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;I tried the following codes:&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;proc sort data=have;&lt;BR /&gt;by study_id;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;proc sql;&lt;BR /&gt;select max(count) into :max_count separated by ' ' from&lt;BR /&gt;(select count(study_ID) as count from have&lt;BR /&gt;group by study_ID);&lt;BR /&gt;quit;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;data want;&lt;BR /&gt;do _n_=1 by 1 until(last.study_ID);&lt;BR /&gt;set have;&lt;BR /&gt;by study_ID;&lt;BR /&gt;array SCORE(*) SCORE0 SCORE3 SCORE12 SCORE24 SCORE36 SCORE48 SCORE60;&lt;BR /&gt;SCORE(_n_)=SCORE;&lt;/P&gt;&lt;P&gt;end;&lt;/P&gt;&lt;P&gt;do until(last.study_ID);&lt;BR /&gt;set have;&lt;BR /&gt;by study_ID;&lt;BR /&gt;output;&lt;BR /&gt;end;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Also tried:&lt;/P&gt;&lt;P&gt;proc sql; (adapted from &lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/13879"&gt;@Reeza&lt;/a&gt;)&lt;BR /&gt;select max(count) into :max_count separated by ' ' from&lt;BR /&gt;(select count(study_ID) as count from have&lt;BR /&gt;group by study_ID);&lt;BR /&gt;quit;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;proc sort data=have;&lt;BR /&gt;by study_id month;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;proc transpose data=have out=want prefix=Score;&lt;/P&gt;&lt;P&gt;by study_ID;&lt;/P&gt;&lt;P&gt;var Score;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;And then did a left-join for the table. However both don't take into account months where a score wasn't recorded so I end up with a table like this&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Study_ID&lt;/TD&gt;&lt;TD&gt;Month&lt;/TD&gt;&lt;TD&gt;Score&lt;/TD&gt;&lt;TD&gt;Score_0&lt;/TD&gt;&lt;TD&gt;Score_3&lt;/TD&gt;&lt;TD&gt;Score_12&lt;/TD&gt;&lt;TD&gt;Score_24&lt;/TD&gt;&lt;TD&gt;Score_36&lt;/TD&gt;&lt;TD&gt;Score_48&lt;/TD&gt;&lt;TD&gt;Score_60&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;56&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;24&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;812&lt;/TD&gt;&lt;TD&gt;60&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;TD&gt;59&lt;/TD&gt;&lt;TD&gt;37&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;34&lt;/TD&gt;&lt;TD&gt;33&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;24&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;813&lt;/TD&gt;&lt;TD&gt;36&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;61&lt;/TD&gt;&lt;TD&gt;51&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;49&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;12&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;24&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;815&lt;/TD&gt;&lt;TD&gt;48&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;TD&gt;47&lt;/TD&gt;&lt;TD&gt;43&lt;/TD&gt;&lt;TD&gt;42&lt;/TD&gt;&lt;TD&gt;41&lt;/TD&gt;&lt;TD&gt;39&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;Where the missing months shifts the remaining scores to the left.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Jon&lt;/P&gt;</description>
      <pubDate>Sun, 09 May 2021 18:49:09 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Retain-Looping-among-multiple-row-record/m-p/740056#M231106</guid>
      <dc:creator>jcsimmo</dc:creator>
      <dc:date>2021-05-09T18:49:09Z</dc:date>
    </item>
    <item>
      <title>Re: Retain + Looping among multiple row record</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Retain-Looping-among-multiple-row-record/m-p/740057#M231107</link>
      <description>&lt;P&gt;You can address this simply via:&lt;/P&gt;
&lt;OL&gt;
&lt;LI&gt;&amp;nbsp;Reading each id twice, first time to populate the SCORE0, SCORE3, ... SCORE60 variables (retained).&amp;nbsp; Second time to output the now complete set of values.&lt;/LI&gt;
&lt;LI&gt;Make an array of SCORE0 through SCORE60, indexed by the month value, making for simple use of the MONTH value (as an array index) to populate the variables.&lt;/LI&gt;
&lt;LI&gt;Judiciously keep a subset of SCORE0 through SCORE60.&lt;/LI&gt;
&lt;/OL&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
  input Study_ID	Month	Score;
datalines;
812	0	56
812	12	37
812	24	36
812	36	35
812	48	34
812	60	33
813	0	61
813	3	51
813	12	50
813	24	49
813	36	48
815	0	47
815	3	43
815	12	42
815	24	41
815	48	39
run;

data want (keep=study_id month score
                score0 score3 score12 score24 score36 score48 score60);

  set have (in=firstpass)
      have (in=secondpass);
  by study_id;

  array _sc{0:60} score0-score60;
  retain score0-score60 ;

  if first.study_id then call missing(of _sc{*});
  if firstpass then _sc{month}=score;
  if secondpass;
run;
&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Note that the array _sc has a lower bound of 0 and upper bound of 60 (and names to match), which will satisfy the minimum and maximum expected value of MONTH.&amp;nbsp; Of course this creates 61 variables, most of which are not kept.&amp;nbsp; But it wonderfully simplifies the use of MONTH as an index pointing to the desired array element.&lt;/P&gt;</description>
      <pubDate>Sun, 09 May 2021 19:35:59 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Retain-Looping-among-multiple-row-record/m-p/740057#M231107</guid>
      <dc:creator>mkeintz</dc:creator>
      <dc:date>2021-05-09T19:35:59Z</dc:date>
    </item>
    <item>
      <title>Re: Retain + Looping among multiple row record</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Retain-Looping-among-multiple-row-record/m-p/740059#M231108</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input Study_ID Month Score;
datalines;
812 0 56
812 12 37
812 24 36
812 36 35
812 48 34
812 60 33
813 0 61
813 3 51
813 12 50
813 24 49
813 36 48
815 0 47
815 3 43
815 12 42
815 24 41
815 48 39
run;

data want(keep=study_id month score score0 score3 score12 score24 score36 
		score48 score60);
	array _score{0:60} score0-score60;
	call missing(of _score[*]);

	do _n_=1 by 1 until(last.Study_ID);
		set have;
		by Study_ID;
		_score[month]=score;
	end;

	do _n_=1 to _n_;
		set have;
		output;
	end;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Sun, 09 May 2021 20:36:29 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Retain-Looping-among-multiple-row-record/m-p/740059#M231108</guid>
      <dc:creator>r_behata</dc:creator>
      <dc:date>2021-05-09T20:36:29Z</dc:date>
    </item>
    <item>
      <title>Re: Retain + Looping among multiple row record</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Retain-Looping-among-multiple-row-record/m-p/740165#M231148</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
  input Study_ID	Month	Score;
datalines;
812	0	56
812	12	37
812	24	36
812	36	35
812	48	34
812	60	33
813	0	61
813	3	51
813	12	50
813	24	49
813	36	48
815	0	47
815	3	43
815	12	42
815	24	41
815	48	39
;
proc transpose data=have out=temp(drop=_name_) prefix=score_;
by study_id;
var month score;
id month;
run;
proc sql noprint;
select cats('score_',month) into :list separated by ' ' from have order by month;
quit;
data want;
retain Study_ID	Month	Score &amp;amp;list ;
 merge have temp;
 by study_id;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 10 May 2021 12:53:50 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Retain-Looping-among-multiple-row-record/m-p/740165#M231148</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2021-05-10T12:53:50Z</dc:date>
    </item>
  </channel>
</rss>

