<?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: Replace prefix of variable for different dataset in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/453726#M114688</link>
    <description>Pay attention - &lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/13879"&gt;@Reeza&lt;/a&gt; relate to the replacement macro, how to simplify it.&lt;BR /&gt;I relate to the second macro.</description>
    <pubDate>Thu, 12 Apr 2018 19:49:52 GMT</pubDate>
    <dc:creator>Shmuel</dc:creator>
    <dc:date>2018-04-12T19:49:52Z</dc:date>
    <item>
      <title>Replace prefix of variable for different dataset</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/453711#M114680</link>
      <description>&lt;P&gt;I got a lot of dataset which each variable start by a letter. By example :&lt;/P&gt;&lt;P&gt;Dataset 1: Avar1 Avar2 Avar3 ..... Avark&lt;/P&gt;&lt;P&gt;Dataset2: Bvar1 Bvar2 Bvar3 .... Bvarn&lt;/P&gt;&lt;P&gt;And I would like them to become :&lt;/P&gt;&lt;P&gt;Dataset 1: Vvar Vvar2 Vvar3 ..... Vvark&lt;/P&gt;&lt;P&gt;Dataset2: Vvar1 Vvar2 Vvar3 .... Vvarn&lt;/P&gt;&lt;P&gt;I found a macro who could do the job for only one dataset :&lt;/P&gt;&lt;PRE&gt;&lt;CODE&gt;` %macro replaceprefix(lib,dsn,start,end,oldprefix,newprefix); 
proc contents data=&amp;amp;lib..&amp;amp;dsn. ; 
title 'before renaming'; 
run; 
data temp; 
set &amp;amp;lib..&amp;amp;dsn.; 
run; 
%LET ds=%SYSFUNC(OPEN(temp,i)); 
%let ol=%length(&amp;amp;oldprefix.); 
%do i=&amp;amp;start %to &amp;amp;end; 
%let dsvn&amp;amp;i=%SYSFUNC(VARNAME(&amp;amp;ds,&amp;amp;i)); 
%let l=%length(&amp;amp;&amp;amp;dsvn&amp;amp;i); 
%let vn&amp;amp;i=&amp;amp;newprefix.%SUBSTR(&amp;amp;&amp;amp;dsvn&amp;amp;i,&amp;amp;ol+1,%EVAL(&amp;amp;l-&amp;amp;ol)); 
%end; 
data &amp;amp;lib..&amp;amp;dsn.; 
set temp; 
%do i=&amp;amp;start %to &amp;amp;end; 
&amp;amp;&amp;amp;vn&amp;amp;i=&amp;amp;&amp;amp;dsvn&amp;amp;i; 
drop &amp;amp;&amp;amp;dsvn&amp;amp;i; 
%end; 
%let rc=%SYSFUNC(CLOSE(&amp;amp;ds)); 
proc contents data=&amp;amp;lib..&amp;amp;dsn.; 
title 'Replacing Prefix on Selected variables '; 
run; &lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;%mend replaceprefix;&lt;BR /&gt;After, I tried to automate this macro for all my dataset. I created the following Macro:&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;  %macro test(end,ele,letter); 
%do k=1 %TO &amp;amp;end; 
%Let i= %scan(&amp;amp;ele,&amp;amp;k); 
%Let j=%scan(&amp;amp;letter,&amp;amp;k);
 %let nvar= %sysfunc(attrnd(&amp;amp;i,nvars));
 %replaceprefix(WORK,&amp;amp;i,1,&amp;amp;nvar,&amp;amp;j,v);
 data &amp;amp;i; set &amp;amp;i; van=&amp;amp;k; run; %end; 
%mend ;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I received the following error code :&lt;/P&gt;&lt;P&gt;&lt;CODE&gt;&amp;nbsp;ERROR: The ATTRND function referenced in the %SYSFUNC or %QSYSFUNC macro function is not found. ERROR: %EVAL function has no expression to evaluate, or %IF statement has no condition.&lt;/CODE&gt;&lt;/P&gt;&lt;P&gt;&lt;CODE&gt;ERROR: The %TO value of the %DO M loop is invalid. &lt;/CODE&gt;&lt;/P&gt;&lt;P&gt;&lt;CODE&gt;ERROR: The macro REPLACEPREFIX will stop executing. ERROR: The ATTRND function referenced in the %SYSFUNC or %QSYSFUNC macro function is not found.&lt;/CODE&gt;&lt;/P&gt;&lt;P&gt;Any idea why ?&lt;/P&gt;&lt;P&gt;Thank's everyone.&lt;/P&gt;</description>
      <pubDate>Thu, 12 Apr 2018 18:57:20 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/453711#M114680</guid>
      <dc:creator>BlaisEcon</dc:creator>
      <dc:date>2018-04-12T18:57:20Z</dc:date>
    </item>
    <item>
      <title>Re: Replace prefix of variable for different dataset</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/453723#M114684</link>
      <description>&lt;P&gt;If the naming convention is well structured, and yours appear to be you can do a mass rename at once, assuming all your indexes are numeric.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;rename avar1-avar200 = VVAR1-VVAR200;

rename bvar1-bvar200 = vvar1-vvar200;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/204426"&gt;@BlaisEcon&lt;/a&gt; wrote:&lt;BR /&gt;
&lt;P&gt;I got a lot of dataset which each variable start by a letter. By example :&lt;/P&gt;
&lt;P&gt;Dataset 1: Avar1 Avar2 Avar3 ..... Avark&lt;/P&gt;
&lt;P&gt;Dataset2: Bvar1 Bvar2 Bvar3 .... Bvarn&lt;/P&gt;
&lt;P&gt;And I would like them to become :&lt;/P&gt;
&lt;P&gt;Dataset 1: Vvar Vvar2 Vvar3 ..... Vvark&lt;/P&gt;
&lt;P&gt;Dataset2: Vvar1 Vvar2 Vvar3 .... Vvarn&lt;/P&gt;
&lt;P&gt;I found a macro who could do the job for only one dataset :&lt;/P&gt;
&lt;PRE&gt;&lt;CODE&gt;` %macro replaceprefix(lib,dsn,start,end,oldprefix,newprefix); 
proc contents data=&amp;amp;lib..&amp;amp;dsn. ; 
title 'before renaming'; 
run; 
data temp; 
set &amp;amp;lib..&amp;amp;dsn.; 
run; 
%LET ds=%SYSFUNC(OPEN(temp,i)); 
%let ol=%length(&amp;amp;oldprefix.); 
%do i=&amp;amp;start %to &amp;amp;end; 
%let dsvn&amp;amp;i=%SYSFUNC(VARNAME(&amp;amp;ds,&amp;amp;i)); 
%let l=%length(&amp;amp;&amp;amp;dsvn&amp;amp;i); 
%let vn&amp;amp;i=&amp;amp;newprefix.%SUBSTR(&amp;amp;&amp;amp;dsvn&amp;amp;i,&amp;amp;ol+1,%EVAL(&amp;amp;l-&amp;amp;ol)); 
%end; 
data &amp;amp;lib..&amp;amp;dsn.; 
set temp; 
%do i=&amp;amp;start %to &amp;amp;end; 
&amp;amp;&amp;amp;vn&amp;amp;i=&amp;amp;&amp;amp;dsvn&amp;amp;i; 
drop &amp;amp;&amp;amp;dsvn&amp;amp;i; 
%end; 
%let rc=%SYSFUNC(CLOSE(&amp;amp;ds)); 
proc contents data=&amp;amp;lib..&amp;amp;dsn.; 
title 'Replacing Prefix on Selected variables '; 
run; &lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;%mend replaceprefix;&lt;BR /&gt;After, I tried to automate this macro for all my dataset. I created the following Macro:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;  %macro test(end,ele,letter); 
%do k=1 %TO &amp;amp;end; 
%Let i= %scan(&amp;amp;ele,&amp;amp;k); 
%Let j=%scan(&amp;amp;letter,&amp;amp;k);
 %let nvar= %sysfunc(attrnd(&amp;amp;i,nvars));
 %replaceprefix(WORK,&amp;amp;i,1,&amp;amp;nvar,&amp;amp;j,v);
 data &amp;amp;i; set &amp;amp;i; van=&amp;amp;k; run; %end; 
%mend ;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I received the following error code :&lt;/P&gt;
&lt;P&gt;&lt;CODE&gt;&amp;nbsp;ERROR: The ATTRND function referenced in the %SYSFUNC or %QSYSFUNC macro function is not found. ERROR: %EVAL function has no expression to evaluate, or %IF statement has no condition.&lt;/CODE&gt;&lt;/P&gt;
&lt;P&gt;&lt;CODE&gt;ERROR: The %TO value of the %DO M loop is invalid. &lt;/CODE&gt;&lt;/P&gt;
&lt;P&gt;&lt;CODE&gt;ERROR: The macro REPLACEPREFIX will stop executing. ERROR: The ATTRND function referenced in the %SYSFUNC or %QSYSFUNC macro function is not found.&lt;/CODE&gt;&lt;/P&gt;
&lt;P&gt;Any idea why ?&lt;/P&gt;
&lt;P&gt;Thank's everyone.&lt;/P&gt;
&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 12 Apr 2018 19:46:11 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/453723#M114684</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2018-04-12T19:46:11Z</dc:date>
    </item>
    <item>
      <title>Re: Replace prefix of variable for different dataset</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/453724#M114685</link>
      <description>&lt;P&gt;1) There is no ATTRND function. You probaly meant to ATTRN.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;2) The syntax to ATTRN function is:&amp;nbsp; ATTRN(dsid, &amp;lt;attribute&amp;gt;)&lt;BR /&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp;You enter NVAR as attribute&amp;nbsp; - that is OK.&lt;/P&gt;
&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp;To get the dataset ID (dsid) you need add a line:&lt;/P&gt;
&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; %let dsid = %sysfunc(open(&amp;lt;dataset_name&amp;gt;));&lt;/P&gt;
&lt;P&gt;&amp;nbsp; &amp;nbsp; I assume that &amp;amp;i - in your code - contains the dsn (dataset name)&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Your code shoul be - try it -&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;%macro test(end,ele,letter); 
    %do k=1 %TO &amp;amp;end; 
        %Let i= %scan(&amp;amp;ele,&amp;amp;k);     /* dataset name ? */
        %Let j=%scan(&amp;amp;letter,&amp;amp;k);

        %let dsid = %sysfunc(open(&amp;amp;i));  /* dataset id */
        %let nvar= %sysfunc(attrnd(&amp;amp;dsid,nvars));
        %let dsid = close(&amp;amp;dsid);     /* resume dataset */

        %replaceprefix(WORK,&amp;amp;i,1,&amp;amp;nvar,&amp;amp;j,v);
        data &amp;amp;i; set &amp;amp;i; van=&amp;amp;k; run; 
  %end; 
%mend ;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 12 Apr 2018 19:46:29 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/453724#M114685</guid>
      <dc:creator>Shmuel</dc:creator>
      <dc:date>2018-04-12T19:46:29Z</dc:date>
    </item>
    <item>
      <title>Re: Replace prefix of variable for different dataset</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/453726#M114688</link>
      <description>Pay attention - &lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/13879"&gt;@Reeza&lt;/a&gt; relate to the replacement macro, how to simplify it.&lt;BR /&gt;I relate to the second macro.</description>
      <pubDate>Thu, 12 Apr 2018 19:49:52 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/453726#M114688</guid>
      <dc:creator>Shmuel</dc:creator>
      <dc:date>2018-04-12T19:49:52Z</dc:date>
    </item>
    <item>
      <title>Re: Replace prefix of variable for different dataset</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/453912#M114744</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data dataset1;
input  Avar1 Avar2 Avar3;
cards;
1 2 3
;
run;

%macro rename(table=);
proc transpose data=&amp;amp;table(obs=0) out=temp;
var _all_;
run;
data _null_;
 set temp end=last;
 if _n_=1 then call execute("proc datasets library=work nolist nodetails;modify &amp;amp;table ;rename ");
 call execute(catt(_name_,'=V',substr(_name_,2)));
 if last then call execute(';quit;');
run;
%mend;

%rename(table=dataset1)&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Fri, 13 Apr 2018 14:04:25 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/453912#M114744</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2018-04-13T14:04:25Z</dc:date>
    </item>
    <item>
      <title>Re: Replace prefix of variable for different dataset</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/454728#M114933</link>
      <description>&lt;P&gt;&lt;SPAN class="mceItemHidden"&gt;Thank you for your answer.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;However,&lt;/P&gt;&lt;P&gt;&lt;SPAN class="mceItemHidden"&gt;When&amp;nbsp;I used your code&amp;nbsp;I get : : "You cannot open WORK.Mere1.DATA for output access with member-level control because&lt;BR /&gt;WORK.Mere1.DATA is in use by you in resource environment DMS Process."&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;do you have any idea why?&lt;/P&gt;</description>
      <pubDate>Tue, 17 Apr 2018 13:48:17 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/454728#M114933</guid>
      <dc:creator>BlaisEcon</dc:creator>
      <dc:date>2018-04-17T13:48:17Z</dc:date>
    </item>
    <item>
      <title>Re: Replace prefix of variable for different dataset</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/454768#M114949</link>
      <description>&lt;P&gt;Do you have the data set open in a viewer?&lt;/P&gt;</description>
      <pubDate>Tue, 17 Apr 2018 14:41:18 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/454768#M114949</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2018-04-17T14:41:18Z</dc:date>
    </item>
    <item>
      <title>Re: Replace prefix of variable for different dataset</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/454769#M114950</link>
      <description>no</description>
      <pubDate>Tue, 17 Apr 2018 14:41:46 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Replace-prefix-of-variable-for-different-dataset/m-p/454769#M114950</guid>
      <dc:creator>BlaisEcon</dc:creator>
      <dc:date>2018-04-17T14:41:46Z</dc:date>
    </item>
  </channel>
</rss>

