阅读(794) (1)

SAS宏

2016-12-12 13:47:32 更新

SAS有一个强大的编程功能叫,它允许我们避免重复的代码段,并在需要时一次又一次地使用它们。 它还有助于在代码中创建动态变量,可以为同一代码的不同运行实例使用不同的值。 宏还可以声明为代码块,它将以类似于宏变量的方式被重复使用多次。 我们将在下面的例子中看到这两个。

宏变量

这些是保存由SAS程序一次又一次使用的值的变量。 它们在SAS程序开始时声明,并在程序体中稍后调用。 它们可以是全局或局部范围。

全局宏观变量

它们称为全局宏变量,因为它们可以由SAS环境中可用的任何SAS程序访问。 通常它们是由多个程序访问的系统分配的变量。 一般的例子是系统日期。

下面是一个名为SYSDATE的SAS变量的示例,它表示系统日期。 考虑一种方案,以便在生成报告的每天的SAS报告的标题中打印系统日期。 标题将显示当前日期和日期,而不为它们编码任何值。 我们使用SASHELP库中提供的名为CARS的内置SAS数据集。

proc print data = sashelp.cars;
where make = 'Audi' and type = 'Sports' ;
 TITLE "Sales as of &SYSDAY &SYSDATE";
run;

当运行上面的代码,我们得到以下输出。

局部宏变量

这些变量可以被SAS程序访问,在这些程序中它们被声明为程序的一部分。 它们通常用于向相同的SAS语句SL提供不同的变量,使得它们可以处理数据集的不同观察值。

句法

局部变量使用下面的语法声明。

% LET (Macro Variable Name) = Value;

这里的值字段可以采取程序所需的任何数字,文本或日期值。 宏变量名是任何有效的SAS变量。

这些变量由SAS语句使用,并在变量名的开头附加字符。 下面的程序得到我们所有的观察的'奥迪'和类型'体育'。 如果我们想要不同make的结果,我们需要更改变量make_name的值,而不改变程序的任何其他部分。 在带来程序的情况下,这个变量可以在任何SAS语句中被再次引用。

%LET make_name = 'Audi';
%LET type_name = 'Sports';
proc print data = sashelp.cars;
where make = &make_name and type = &type_name ;
 TITLE "Sales as of &SYSDAY &SYSDATE";
run;

当上面的代码运行时,我们得到与上一个程序相同的输出。 但是让我们将type_name改为'Wagon',并运行相同的程序。 我们将得到以下结果。

宏程序

宏是一组SAS语句,由名称引用,并在程序中使用该名称在任何地方使用它。 它以%MACRO语句开始,以%MEND语句结束。

句法

局部变量使用下面的语法声明。

# Creating a Macro program.
%MACRO (Param1, Param2,….Paramn);

Macro Statements;

%MEND;

# Calling a Macro program.
%MacroName (Value1, Value2,…..Valuen);

以下程序在名为“show_result”的宏下对一组SAT staemnets进行解密; 此宏正由其他SAS语句调用。

%MACRO show_result(make_ , type_);
proc print data = sashelp.cars;
where make = "&make_" and type = "&type_" ;
TITLE "Sales as of &SYSDAY &SYSDATE";
run;
%MEND;

%show_result(BMW,SUV);

当运行上面的代码,我们得到以下输出。

常用的宏

SAS有许多MACRO语句,它们内置在SAS编程语言中。 它们被其他SAS程序使用,而没有明确声明它们。 常见的例子是 - 当满足一些条件时终止程序或捕获程序日志中变量的运行时值。 下面是一些例子。

宏%PUT

此宏语句将文本或宏变量信息写入SAS日志。 在下面的例子中,变量“today”的值被写入程序日志。

data _null_;
CALL SYMPUT ('today',
TRIM(PUT("&sysdate"d,worddate22.)));
run;
%put &today;

宏%RETURN

当某个条件的计算结果为真时,执行该宏将导致当前执行的宏正常终止。 在下面的示例中,当变量“val”的值变为10时,宏终止其它连接。

%macro check_condition(val);
   %if &val = 10 %then %return;

    data p;
       x=34.2;
    run;  

%mend check_condition;  

%check_condition(11)  ;

宏%END

此宏定义包含一个%DO%WHILE循环,根据需要以%END语句结束。 在下面的示例中,名为test的宏采用用户输入,并使用此输入值运行DO循环。 DO循环的结束通过%end语句实现,而宏的结束通过%mend语句实现。

%macro test(finish);
   %let i=1;
   %do %while (&i <&finish);
      %put the value of i is &i;
      %let i=%eval(&i+1);
   %end;
%mend test;
%test(5)