如何使用sas

时间:2016-04-13 11:14:56

标签: sas renaming

我有一个包含100个变量的SAS数据集DATA。不幸的是,这个数据集不包含每个变量的名称。它只是将变量命名为VAR1 - Var100。我有一个单独的文件,列出了每个变量Name的名称(每个单元一个名称)。我不想一个一个地重命名它,所以下面的代码不是一个选项。

data lib.test (rename = (var1= truename1 var2 = truename2 ...) ;
   set lib.test;
run;

根据Reeze的建议,我尝试实施以下解决方案http://stackoverflow.com/questions/29006915/rename-variable-regardless-of-its-name-in-sas

proc sql;
   /* Write the individual rename assignments */
   select strip(name) || " = " || substr("ABCDEFGHIJKLMNOPQRSTUVWXYZ", varnum , 1)

   /* Store them in a macro variable and separate them by spaces */
   into :vars separated by " "

   /* Use a sas dictionary table to find metadata about the dataset */
   from sashelp.vcolumn
   where libname = "LIB"
     and memname = "TEST"
     and 1 <= varnum <= 100;
quit;

proc datasets lib=lib nolist nodetails;
   modify test;
   rename &vars.;
quit;

现在,我不想使用a,b,c,d ...来重命名我的变量,而是希望将数据集Name上的名称用作新名称。数据集Name如下所示(如果更容易使用,我可以转置它)。 Name的顺序与数据集lib.test中的变量序列相同。如何更改上面的代码才能实现此目的?

Name
name1
anc
sjsjd
mdmd

1 个答案:

答案 0 :(得分:3)

您可以将NAME数据集转换为包含旧名称和新名称,然后使用它来生成重命名对。

data name_pairs;
  set name ;
  old_name = cats('VAR',_n_);
run;

proc sql noprint ;
  select catx('=',old_name,name)
    into :vars separated by ' ' 
    from name_pairs
  ;
quit;

然后,您可以在重命名语句中使用宏变量VARS