<?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 Merging datasets where values of a variable  become variables in output dataset in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Merging-datasets-where-values-of-a-variable-become-variables-in/m-p/334112#M75418</link>
    <description>&lt;P&gt;Dear,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am merging the two datsets. I got the output I need by several datasteps. But i want to do a better way and reduce the code.Please suggest. Thank you&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;data one;&lt;BR /&gt;input id seq;&lt;BR /&gt;datalines;&lt;BR /&gt;1 1&lt;BR /&gt;1 2&lt;BR /&gt;2 2&lt;BR /&gt;2 3&lt;BR /&gt;3 1&lt;BR /&gt;4 2&lt;BR /&gt;5 4&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;data suppone;&lt;BR /&gt;input id idvar $ nam $ val $;&lt;BR /&gt;datalines;&lt;BR /&gt;1 1 act aaa&lt;BR /&gt;2 3 act aab&lt;BR /&gt;2 3 act1 bbb&lt;BR /&gt;3 1 act ccc&lt;BR /&gt;3 1 act1 cc1&lt;BR /&gt;3 1 act2 cc2&lt;BR /&gt;4 2 act ddd&lt;BR /&gt;5 4 act eee&lt;BR /&gt;5 4 act1 ee1&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;/*The suppone dataset in split into multiple datasets by "nam" varibale*/&lt;BR /&gt;&lt;BR /&gt;data act act1 act2 act3;&lt;BR /&gt;set suppone;&lt;BR /&gt;if nam='act' then output act;&lt;BR /&gt;if nam='act1' then output act1;&lt;BR /&gt;if nam='act2' then output act2;&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;data sact;&lt;BR /&gt;set act;&lt;BR /&gt;seq=input(idvarval,best.);&lt;BR /&gt;rename val=act;&lt;BR /&gt;drop nam;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;Repeated the above step for all and then merged with dataone by id seq.&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;output needed:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;ID &amp;nbsp; &amp;nbsp;seq &amp;nbsp; &amp;nbsp;act &amp;nbsp; &amp;nbsp; act1 &amp;nbsp; &amp;nbsp; act2&lt;BR /&gt;1 &amp;nbsp; &amp;nbsp; &amp;nbsp; 1 &amp;nbsp; &amp;nbsp; aaa&lt;BR /&gt;1 &amp;nbsp; &amp;nbsp; &amp;nbsp; 2&lt;BR /&gt;2 &amp;nbsp; &amp;nbsp; &amp;nbsp; 2&lt;BR /&gt;2 &amp;nbsp; &amp;nbsp; &amp;nbsp; 3 &amp;nbsp; &amp;nbsp; bbb &amp;nbsp; &amp;nbsp; &amp;nbsp;bb1&lt;BR /&gt;3 &amp;nbsp; &amp;nbsp; &amp;nbsp; 1 &amp;nbsp; &amp;nbsp; ccc &amp;nbsp; &amp;nbsp; &amp;nbsp; cc1 &amp;nbsp; &amp;nbsp; &amp;nbsp; cc2&lt;BR /&gt;4 &amp;nbsp; &amp;nbsp; &amp;nbsp; 2 &amp;nbsp; &amp;nbsp;ddd&lt;BR /&gt;5 &amp;nbsp; &amp;nbsp; &amp;nbsp;4 &amp;nbsp; &amp;nbsp; eee &amp;nbsp; &amp;nbsp; &amp;nbsp; ee1&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Sat, 18 Feb 2017 18:29:51 GMT</pubDate>
    <dc:creator>knveraraju91</dc:creator>
    <dc:date>2017-02-18T18:29:51Z</dc:date>
    <item>
      <title>Merging datasets where values of a variable  become variables in output dataset</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Merging-datasets-where-values-of-a-variable-become-variables-in/m-p/334112#M75418</link>
      <description>&lt;P&gt;Dear,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am merging the two datsets. I got the output I need by several datasteps. But i want to do a better way and reduce the code.Please suggest. Thank you&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;data one;&lt;BR /&gt;input id seq;&lt;BR /&gt;datalines;&lt;BR /&gt;1 1&lt;BR /&gt;1 2&lt;BR /&gt;2 2&lt;BR /&gt;2 3&lt;BR /&gt;3 1&lt;BR /&gt;4 2&lt;BR /&gt;5 4&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;data suppone;&lt;BR /&gt;input id idvar $ nam $ val $;&lt;BR /&gt;datalines;&lt;BR /&gt;1 1 act aaa&lt;BR /&gt;2 3 act aab&lt;BR /&gt;2 3 act1 bbb&lt;BR /&gt;3 1 act ccc&lt;BR /&gt;3 1 act1 cc1&lt;BR /&gt;3 1 act2 cc2&lt;BR /&gt;4 2 act ddd&lt;BR /&gt;5 4 act eee&lt;BR /&gt;5 4 act1 ee1&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;/*The suppone dataset in split into multiple datasets by "nam" varibale*/&lt;BR /&gt;&lt;BR /&gt;data act act1 act2 act3;&lt;BR /&gt;set suppone;&lt;BR /&gt;if nam='act' then output act;&lt;BR /&gt;if nam='act1' then output act1;&lt;BR /&gt;if nam='act2' then output act2;&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;data sact;&lt;BR /&gt;set act;&lt;BR /&gt;seq=input(idvarval,best.);&lt;BR /&gt;rename val=act;&lt;BR /&gt;drop nam;&lt;BR /&gt;run;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;Repeated the above step for all and then merged with dataone by id seq.&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;output needed:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;ID &amp;nbsp; &amp;nbsp;seq &amp;nbsp; &amp;nbsp;act &amp;nbsp; &amp;nbsp; act1 &amp;nbsp; &amp;nbsp; act2&lt;BR /&gt;1 &amp;nbsp; &amp;nbsp; &amp;nbsp; 1 &amp;nbsp; &amp;nbsp; aaa&lt;BR /&gt;1 &amp;nbsp; &amp;nbsp; &amp;nbsp; 2&lt;BR /&gt;2 &amp;nbsp; &amp;nbsp; &amp;nbsp; 2&lt;BR /&gt;2 &amp;nbsp; &amp;nbsp; &amp;nbsp; 3 &amp;nbsp; &amp;nbsp; bbb &amp;nbsp; &amp;nbsp; &amp;nbsp;bb1&lt;BR /&gt;3 &amp;nbsp; &amp;nbsp; &amp;nbsp; 1 &amp;nbsp; &amp;nbsp; ccc &amp;nbsp; &amp;nbsp; &amp;nbsp; cc1 &amp;nbsp; &amp;nbsp; &amp;nbsp; cc2&lt;BR /&gt;4 &amp;nbsp; &amp;nbsp; &amp;nbsp; 2 &amp;nbsp; &amp;nbsp;ddd&lt;BR /&gt;5 &amp;nbsp; &amp;nbsp; &amp;nbsp;4 &amp;nbsp; &amp;nbsp; eee &amp;nbsp; &amp;nbsp; &amp;nbsp; ee1&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Sat, 18 Feb 2017 18:29:51 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Merging-datasets-where-values-of-a-variable-become-variables-in/m-p/334112#M75418</guid>
      <dc:creator>knveraraju91</dc:creator>
      <dc:date>2017-02-18T18:29:51Z</dc:date>
    </item>
    <item>
      <title>Re: Merging datasets where values of a variable  become variables in output dataset</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Merging-datasets-where-values-of-a-variable-become-variables-in/m-p/334124#M75427</link>
      <description>&lt;P&gt;Assuming that your desired output contains the following error:&lt;/P&gt;
&lt;P&gt;&lt;SPAN&gt;2 &amp;nbsp; &amp;nbsp; &amp;nbsp; 3 &amp;nbsp; &amp;nbsp; bbb &amp;nbsp; &amp;nbsp; &amp;nbsp;bb1 &amp;nbsp;should really be&amp;nbsp;2 &amp;nbsp; &amp;nbsp; &amp;nbsp; 3 &amp;nbsp; &amp;nbsp; aab &amp;nbsp; &amp;nbsp; &amp;nbsp;bb1&lt;/SPAN&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;SPAN&gt;then the following would be easier:&lt;/SPAN&gt;&lt;/P&gt;
&lt;P&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;/P&gt;
&lt;PRE&gt;data new_suppone (drop=_:);
  set suppone (rename=(idvar=_idvar));
  idvar=input(_idvar, 8.);
run;

proc transpose data=new_suppone out=supponet ( drop=_: rename=(idvar=seq));
  var val;
  id nam;
  by id idvar;
run;

data want;
  merge one supponet;
  by id seq;
run;
&lt;/PRE&gt;</description>
      <pubDate>Sat, 18 Feb 2017 19:38:23 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Merging-datasets-where-values-of-a-variable-become-variables-in/m-p/334124#M75427</guid>
      <dc:creator>art297</dc:creator>
      <dc:date>2017-02-18T19:38:23Z</dc:date>
    </item>
    <item>
      <title>Re: Merging datasets where values of a variable  become variables in output dataset</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Merging-datasets-where-values-of-a-variable-become-variables-in/m-p/334167#M75447</link>
      <description>For the merging I would use SQL since it's more flexible and allows manipulation of join column in the same step. &lt;BR /&gt;Your end result looks more like a report and for that I would suggest PROC TABULATE or REPORT.</description>
      <pubDate>Sun, 19 Feb 2017 06:05:26 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Merging-datasets-where-values-of-a-variable-become-variables-in/m-p/334167#M75447</guid>
      <dc:creator>LinusH</dc:creator>
      <dc:date>2017-02-19T06:05:26Z</dc:date>
    </item>
  </channel>
</rss>

