从宏变量SAS创建数据集



我有一个宏变量,它存储一个名称字符串,例如:

%let operation =加减除乘;

我想将宏中的每个元素(以观察值显示)转换为数据集变量。所以数据集应该是这样的:

<obs> <operation>
<1>   add
<2>   subtract
<3>   divide
<4>   multiply

使用SCAN()函数。默认分隔符将适用于您的示例,否则您可以指定要使用的确切分隔符。

%let operation= add subtract divide multiply;
data want ;
  length obs 8 operation $20 ;
  do obs=1 by 1 until (operation=' ');
    operation=scan("&operation",obs);
    if operation ne ' ' then output;
  end;
run;

我仍然不太清楚你有什么,你想要什么。这个例子是人为的,但可能会给你一些关于语法等方面的帮助。

%let operation = add subtract multiply divide;
data operation;
   length &operation 8;
   array operation[*] &operation (2 3 10 4);
   put 'NOTE: ' (operation[*])(=);
   run;
*data set of names;
proc transpose data=operation(obs=0) out=names name=operation;
   var &operation;
   run;
proc print;
   run;

最新更新