<?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 Deriving data values from first value of each observation into new variable in New SAS User</title>
    <link>https://communities.sas.com/t5/New-SAS-User/Deriving-data-values-from-first-value-of-each-observation-into/m-p/612556#M18308</link>
    <description>&lt;P&gt;data sv_raw;&lt;BR /&gt;input PT_ID $ Visit $ Res ;&lt;BR /&gt;datalines;&lt;BR /&gt;1 1 20&lt;BR /&gt;1 2 40&lt;BR /&gt;1 3 30&lt;BR /&gt;2 1 30&lt;BR /&gt;2 2 40&lt;BR /&gt;2 3 50&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Need output: The result of first value of patient should be populated in Base (Variable) like below.&lt;/P&gt;&lt;P&gt;objective is New variable has to be created in the&amp;nbsp; name of base, the data value is 'first value of res(result) variable'&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;PT_ID&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Visit&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Res&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Base&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;20&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;20&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;40&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;20&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;3&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;30&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;20&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;30&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;30&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;40&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;30&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;3&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;30&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;My code;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;data sv_raw;&lt;BR /&gt;input PT_ID $ Visit $ Res $;&lt;BR /&gt;datalines;&lt;BR /&gt;1 1 20&lt;BR /&gt;1 2 40&lt;BR /&gt;1 3 30&lt;BR /&gt;2 1 30&lt;BR /&gt;2 2 40&lt;BR /&gt;2 3 50&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;proc sort data=sv_raw out=sv;&lt;BR /&gt;by PT_ID Visit Res;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;data baseline;&lt;BR /&gt;set sv;&lt;BR /&gt;by PT_ID Visit Res;&lt;BR /&gt;if not missing(PT_ID)then Base = first.res;&lt;BR /&gt;run;&lt;/P&gt;</description>
    <pubDate>Wed, 18 Dec 2019 01:49:19 GMT</pubDate>
    <dc:creator>tsureshinvites</dc:creator>
    <dc:date>2019-12-18T01:49:19Z</dc:date>
    <item>
      <title>Deriving data values from first value of each observation into new variable</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Deriving-data-values-from-first-value-of-each-observation-into/m-p/612556#M18308</link>
      <description>&lt;P&gt;data sv_raw;&lt;BR /&gt;input PT_ID $ Visit $ Res ;&lt;BR /&gt;datalines;&lt;BR /&gt;1 1 20&lt;BR /&gt;1 2 40&lt;BR /&gt;1 3 30&lt;BR /&gt;2 1 30&lt;BR /&gt;2 2 40&lt;BR /&gt;2 3 50&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Need output: The result of first value of patient should be populated in Base (Variable) like below.&lt;/P&gt;&lt;P&gt;objective is New variable has to be created in the&amp;nbsp; name of base, the data value is 'first value of res(result) variable'&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;PT_ID&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Visit&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Res&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Base&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;20&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;20&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;40&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;20&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;3&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;30&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;20&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;30&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;30&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;40&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;30&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;2&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;3&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;50&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;30&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;My code;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;data sv_raw;&lt;BR /&gt;input PT_ID $ Visit $ Res $;&lt;BR /&gt;datalines;&lt;BR /&gt;1 1 20&lt;BR /&gt;1 2 40&lt;BR /&gt;1 3 30&lt;BR /&gt;2 1 30&lt;BR /&gt;2 2 40&lt;BR /&gt;2 3 50&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;proc sort data=sv_raw out=sv;&lt;BR /&gt;by PT_ID Visit Res;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;data baseline;&lt;BR /&gt;set sv;&lt;BR /&gt;by PT_ID Visit Res;&lt;BR /&gt;if not missing(PT_ID)then Base = first.res;&lt;BR /&gt;run;&lt;/P&gt;</description>
      <pubDate>Wed, 18 Dec 2019 01:49:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Deriving-data-values-from-first-value-of-each-observation-into/m-p/612556#M18308</guid>
      <dc:creator>tsureshinvites</dc:creator>
      <dc:date>2019-12-18T01:49:19Z</dc:date>
    </item>
    <item>
      <title>Re: Deriving data values from first value of each observation into new variable</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Deriving-data-values-from-first-value-of-each-observation-into/m-p/612557#M18309</link>
      <description>&lt;P&gt;hi&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/293333"&gt;@tsureshinvites&lt;/a&gt;&amp;nbsp; &amp;nbsp;are you asking for this ?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data sv_raw;
input PT_ID $ Visit $ Res ;
datalines;
1 1 20
1 2 40
1 3 30
2 1 30
2 2 40
2 3 50
;

data want;
set sv_raw;
by PT_ID;
retain base;
if first.PT_ID then base=res;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Wed, 18 Dec 2019 01:59:14 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Deriving-data-values-from-first-value-of-each-observation-into/m-p/612557#M18309</guid>
      <dc:creator>novinosrin</dc:creator>
      <dc:date>2019-12-18T01:59:14Z</dc:date>
    </item>
    <item>
      <title>Re: Deriving data values from first value of each observation into new variable</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Deriving-data-values-from-first-value-of-each-observation-into/m-p/612558#M18310</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data sv_raw;
input PT_ID $ Visit $ Res ;
datalines;
1 1 20
1 2 40
1 3 30
2 1 30
2 2 40
2 3 50
;

proc sql;
create table want as
select a.*, base
from sv_raw a,(select pt_id,res as base from sv_raw where visit='1') b
where a.pt_id=b.pt_id
order by pt_id, visit;
quit;
&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Wed, 18 Dec 2019 02:08:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Deriving-data-values-from-first-value-of-each-observation-into/m-p/612558#M18310</guid>
      <dc:creator>novinosrin</dc:creator>
      <dc:date>2019-12-18T02:08:19Z</dc:date>
    </item>
    <item>
      <title>Re: Deriving data values from first value of each observation into new variable</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Deriving-data-values-from-first-value-of-each-observation-into/m-p/612568#M18311</link>
      <description>&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;This might be a good situation for a merge statement, as in:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data sv_raw;
input PT_ID $ Visit  Res ;
datalines;
1 1 20
1 2 40
1 3 30
2 1 30
2 2 40
2 3 50
run;

data want;
  merge sv_raw (keep=pt_id visit res rename=(res=base) where=(visit=1))
        sv_raw;
  by pt_id;
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;This program assumes that:&lt;/P&gt;
&lt;OL&gt;
&lt;LI&gt;The data are sorted by PT_ID&lt;/LI&gt;
&lt;LI&gt;Each&amp;nbsp;PT_ID has one record with visit=1.&lt;/LI&gt;
&lt;/OL&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;The program is a 1-to-many match merge based on PT_ID.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp; if matches a subset of&amp;nbsp;SV_RAW (namely only observations with visit=1) will all of SV_RAW, matched on PT_ID.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;But both the subset and the complete set have a variable named RES, so to avoid a "collision" I rename the RES in the subset to BASE.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;You might note there would be a collision of VISIT also.&amp;nbsp; But when there is a collision,&amp;nbsp;it will be&amp;nbsp;the latter instance of visit (from the complete set) that overwrites the value from the earlier instance (the visit=1 subset).&amp;nbsp;&amp;nbsp;&amp;nbsp; In other words, the order of the two objects of the MERGE statement matters.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;This order would be wrong&lt;BR /&gt;&amp;nbsp;&amp;nbsp; merge have&lt;/P&gt;
&lt;P&gt;&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; have (keep=pt_id visit res rename(res=base) where=(visit=1));&lt;/P&gt;
&lt;P&gt;because the value of visit=1 would overwrite all the visit values from the other records.&lt;/P&gt;</description>
      <pubDate>Wed, 18 Dec 2019 03:55:27 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Deriving-data-values-from-first-value-of-each-observation-into/m-p/612568#M18311</guid>
      <dc:creator>mkeintz</dc:creator>
      <dc:date>2019-12-18T03:55:27Z</dc:date>
    </item>
  </channel>
</rss>

