<?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: Collapsing records for vital signs in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Collapsing-records-for-vital-signs/m-p/945323#M370384</link>
    <description>&lt;P&gt;If you want the variables to have the LAST non missing value per group then use the UPDATE statement to treat the records as transactions.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
  update have(obs=0) have;
  by SUBJECT VISIT TIMEPOINT  ;
run;
&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;The UPDATE statement needs two dataset.&amp;nbsp; The original data and the transaction records.&amp;nbsp; The original data needs to have one observation per BY group.&amp;nbsp; But you can have multiple transaction records per BY group.&amp;nbsp; So just use an empty version of the data (by using the OBS=0 dataset option) as the original data and all of the observations as transactions.&lt;/P&gt;</description>
    <pubDate>Thu, 26 Sep 2024 12:55:22 GMT</pubDate>
    <dc:creator>Tom</dc:creator>
    <dc:date>2024-09-26T12:55:22Z</dc:date>
    <item>
      <title>Collapsing records for vital signs</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Collapsing-records-for-vital-signs/m-p/945309#M370376</link>
      <description>&lt;P&gt;Hi, I have a vital signs data set with multiple rows per subject/visit/timepoint. I would like to collapse the data so there is one row per&amp;nbsp;subject/visit/timepoint.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Have:&lt;/P&gt;
&lt;P&gt;SUBJECT VISIT TIMEPOINT&amp;nbsp; TEMP&amp;nbsp; &amp;nbsp; SYSBP DIABP&amp;nbsp;&lt;/P&gt;
&lt;P&gt;101&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;C1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; PRE&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; .&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;.&lt;/P&gt;
&lt;P&gt;101&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;C1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; PRE&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; .&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;21&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;43&lt;/P&gt;
&lt;P&gt;101&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;C2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;POST&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; .&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;2 5&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 46&lt;/P&gt;
&lt;P&gt;102&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; C1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; PRE&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;22&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 32&lt;/P&gt;
&lt;P&gt;102&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; C1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;POST&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; .&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 56&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; .&lt;/P&gt;
&lt;P&gt;102&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; C1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;POST&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; .&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 25&lt;/P&gt;
&lt;P&gt;102&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;C2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;POST&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;5&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;55&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 54&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Want:&lt;/P&gt;
&lt;P&gt;SUBJECT VISIT TIMEPOINT&amp;nbsp; TEMP&amp;nbsp; &amp;nbsp; SYSBP DIABP&amp;nbsp;&lt;/P&gt;
&lt;P&gt;101&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;C1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; PRE&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;21&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;43&lt;/P&gt;
&lt;P&gt;101&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;C2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;POST&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; .&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;2 5&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 46&lt;/P&gt;
&lt;P&gt;102&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; C1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; PRE&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;22&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 32&lt;/P&gt;
&lt;P&gt;102&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; C1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;POST&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;56&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;25&lt;/P&gt;
&lt;P&gt;102&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;C2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;POST&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;5&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;55&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 54&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 26 Sep 2024 10:20:48 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Collapsing-records-for-vital-signs/m-p/945309#M370376</guid>
      <dc:creator>kalbo</dc:creator>
      <dc:date>2024-09-26T10:20:48Z</dc:date>
    </item>
    <item>
      <title>Re: Collapsing records for vital signs</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Collapsing-records-for-vital-signs/m-p/945310#M370377</link>
      <description>&lt;P&gt;Assuming the pattern you show is always the pattern in the real data, with in each column only one number and the rest are missing for each&amp;nbsp;&lt;SPAN&gt;subject/visit/timepoint, then this is a perfect job for PROC SUMMARY&lt;/SPAN&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc summary data=have nway;
    class subject visit timepoint;
    var temp sysbp diabp;
    output out=want mean=;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 26 Sep 2024 10:40:52 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Collapsing-records-for-vital-signs/m-p/945310#M370377</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2024-09-26T10:40:52Z</dc:date>
    </item>
    <item>
      <title>Re: Collapsing records for vital signs</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Collapsing-records-for-vital-signs/m-p/945323#M370384</link>
      <description>&lt;P&gt;If you want the variables to have the LAST non missing value per group then use the UPDATE statement to treat the records as transactions.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
  update have(obs=0) have;
  by SUBJECT VISIT TIMEPOINT  ;
run;
&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;The UPDATE statement needs two dataset.&amp;nbsp; The original data and the transaction records.&amp;nbsp; The original data needs to have one observation per BY group.&amp;nbsp; But you can have multiple transaction records per BY group.&amp;nbsp; So just use an empty version of the data (by using the OBS=0 dataset option) as the original data and all of the observations as transactions.&lt;/P&gt;</description>
      <pubDate>Thu, 26 Sep 2024 12:55:22 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Collapsing-records-for-vital-signs/m-p/945323#M370384</guid>
      <dc:creator>Tom</dc:creator>
      <dc:date>2024-09-26T12:55:22Z</dc:date>
    </item>
  </channel>
</rss>

