<?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: PROC Transpose with missing value in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504686#M135110</link>
    <description>Thanks V_27! It works perfectly.</description>
    <pubDate>Tue, 16 Oct 2018 12:29:04 GMT</pubDate>
    <dc:creator>dera</dc:creator>
    <dc:date>2018-10-16T12:29:04Z</dc:date>
    <item>
      <title>PROC Transpose with missing value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504471#M134998</link>
      <description>&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I have a data set that looks like this and I want to transpose it to have only one observation for each ID.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE cellspacing="0" cellpadding="0" border="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;id&lt;/TD&gt;&lt;TD&gt;col1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;5&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;1&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;When I do PROC transpose with the code below, I get this:&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc transpose data=have out=want prefix = variable;
	by id;
	var col1;
run;&lt;/CODE&gt;&lt;/PRE&gt;&lt;TABLE cellspacing="0" cellpadding="0" border="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;id&lt;/TD&gt;&lt;TD&gt;variable1&lt;/TD&gt;&lt;TD&gt;variable2&lt;/TD&gt;&lt;TD&gt;variable3&lt;/TD&gt;&lt;TD&gt;variable4&lt;/TD&gt;&lt;TD&gt;variable5&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;5&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&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;For ID 1 to 3 and 5, everything is okay but my question is for ID = 4. Is there a way to ignore the missing value in the the first two variables and assign variable 3 instead?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Here is what I want (I will eventually remove the variable that are completely empty)&lt;/P&gt;&lt;TABLE cellspacing="0" cellpadding="0" border="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;id&lt;/TD&gt;&lt;TD&gt;variable1&lt;/TD&gt;&lt;TD&gt;variable2&lt;/TD&gt;&lt;TD&gt;variable3&lt;/TD&gt;&lt;TD&gt;variable4&lt;/TD&gt;&lt;TD&gt;variable5&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;5&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;.&lt;/TD&gt;&lt;TD&gt;.&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;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks&lt;/P&gt;</description>
      <pubDate>Mon, 15 Oct 2018 20:01:04 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504471#M134998</guid>
      <dc:creator>dera</dc:creator>
      <dc:date>2018-10-15T20:01:04Z</dc:date>
    </item>
    <item>
      <title>Re: PROC Transpose with missing value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504483#M135002</link>
      <description>&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Hi&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/236159"&gt;@dera&lt;/a&gt;,&lt;/P&gt;&lt;P&gt;Try sorting id in ascending and col1 in descending order. Check the given sas code.&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sort data=have out=new;
by id descending col1;
run;

proc transpose data=new out=want prefix=variable;
	by id;
	var col1;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 15 Oct 2018 20:29:05 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504483#M135002</guid>
      <dc:creator>V_27</dc:creator>
      <dc:date>2018-10-15T20:29:05Z</dc:date>
    </item>
    <item>
      <title>Re: PROC Transpose with missing value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504484#M135003</link>
      <description>&lt;P&gt;I think you have to perform the operation afterwards, like this&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input id col1;
datalines;
1 1
1 1
1 0
2 0
2 0
3 1
4 .
4 .
4 1
4 1
4 0
5 1
;

proc transpose data=have out=want prefix = variable;
	by id;
	var col1;
run;

data final (drop=variable1-variable5 j i);
   set want;
   array in variable1-variable5;
   array out $ var1-var5;
   j=1;
   do i=1 to 5;
      if in(i) ne ' ' then do;
         out(j)=in(i);
         j+1;
      end;
   end;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 15 Oct 2018 20:31:53 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504484#M135003</guid>
      <dc:creator>PeterClemmensen</dc:creator>
      <dc:date>2018-10-15T20:31:53Z</dc:date>
    </item>
    <item>
      <title>Re: PROC Transpose with missing value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504485#M135004</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input id	col1;
cards;
1	1
1	1
1	0
2	0
2	0
3	1
4	.
4	.
4	1
4	1
4	0
5 1 
;
data want;
do  until(last.id);
set have;
by id ;
array  variable(5);
if first.id then call missing(of variable(*),_c);
if not missing(col1) then do;
_c+1;
variable(_c)=col1;
end;
end;
drop _: col1;
run;




 &lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 15 Oct 2018 20:33:03 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504485#M135004</guid>
      <dc:creator>novinosrin</dc:creator>
      <dc:date>2018-10-15T20:33:03Z</dc:date>
    </item>
    <item>
      <title>Re: PROC Transpose with missing value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504492#M135008</link>
      <description>&lt;P&gt;Hello&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/236159"&gt;@dera&lt;/a&gt;,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;What if the first COL1 value of ID 4 was not missing? Would you still ignore the missing value in the second observation of this ID?&lt;/P&gt;
&lt;P&gt;If so, you could simply insert a WHERE&amp;nbsp;statement into your PROC TRANSPOSE step, e.g.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;where col1&amp;gt;.;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 15 Oct 2018 20:59:31 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504492#M135008</guid>
      <dc:creator>FreelanceReinh</dc:creator>
      <dc:date>2018-10-15T20:59:31Z</dc:date>
    </item>
    <item>
      <title>Re: PROC Transpose with missing value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504686#M135110</link>
      <description>Thanks V_27! It works perfectly.</description>
      <pubDate>Tue, 16 Oct 2018 12:29:04 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504686#M135110</guid>
      <dc:creator>dera</dc:creator>
      <dc:date>2018-10-16T12:29:04Z</dc:date>
    </item>
    <item>
      <title>Re: PROC Transpose with missing value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504691#M135113</link>
      <description>&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;You are most welcome&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/236159"&gt;@dera&lt;/a&gt;&amp;nbsp;&lt;img id="smileyhappy" class="emoticon emoticon-smileyhappy" src="https://communities.sas.com/i/smilies/16x16_smiley-happy.png" alt="Smiley Happy" title="Smiley Happy" /&gt;&lt;/P&gt;</description>
      <pubDate>Tue, 16 Oct 2018 12:46:55 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/PROC-Transpose-with-missing-value/m-p/504691#M135113</guid>
      <dc:creator>V_27</dc:creator>
      <dc:date>2018-10-16T12:46:55Z</dc:date>
    </item>
  </channel>
</rss>

