首页 > 解决方案 > symputx 不允许我使用相同的宏函数存储不同的宏变量

问题描述

我正在尝试编写一个宏函数,该函数从数据集中获取属性,然后将它们存储为宏变量。我想以这样一种方式编写这个宏函数,它可以用于多个数据集和多个宏变量。

这有什么问题:

%macro ExtractACell(dataset, storage_var, rownum=1, var_name=Make);
data _null_;
    set &dataset. (obs=&rownum. firstobs=&rownum. keep = &var_name.);   
    call symputx(&storage_var., &var_name., "G");
    stop;
run;
%mend ExtractACell;

每当我尝试运行时,我都会收到这样的注释:

 NOTE: The quoted string currently being processed has become more than 262 bytes long.  You might have unbalanced quotation marks.
 NOTE: The quoted string currently being processed has become more than 262 bytes long.  You might have unbalanced quotation marks.
 27         %let SASWORKLOCATION="%sysfunc(getoption(work))/";

是否symputx有禁止传入代表宏变量名称的宏变量的规则?

标签: sassas-macro

解决方案


确保在扩展宏变量时生成有效的 SAS 代码。特别是这个声明:

call symputx(&storage_var., &var_name., "G");

将要求您在要创建的宏变量的名称周围使用引号来调用宏。像这样:

%ExtractACell(dataset=sashelp.cars, storage_var="mymvar", rownum=1, var_name=Make);

使用此语句对宏进行编码可能更简单。

call symputx("&storage_var", &var_name., "G");

然后您可以在宏变量名称周围不带引号的情况下调用:

%ExtractACell(dataset=sashelp.cars, storage_var=mymvar, rownum=1, var_name=Make);

PS如果你需要那个宏,你的整个过程可能会搞砸。


推荐阅读