课程表

SAS 基础

SAS 数据集操作

SAS 数据展示

SAS 基本统计程序

工具箱
速查手册

SAS宏

当前位置:免费教程 » 大数据/云 » SAS

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

宏变量

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

全局宏观变量

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

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

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

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

局部宏变量

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

句法

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

  1. % LET (Macro Variable Name) = Value;

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

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

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

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

宏程序

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

句法

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

  1. # Creating a Macro program.
  2. %MACRO (Param1, Param2,….Paramn);
  3.  
  4. Macro Statements;
  5.  
  6. %MEND;
  7.  
  8. # Calling a Macro program.
  9. %MacroName (Value1, Value2,…..Valuen);

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

  1. %MACRO show_result(make_ , type_);
  2. proc print data = sashelp.cars;
  3. where make = "&make_" and type = "&type_" ;
  4. TITLE "Sales as of &SYSDAY &SYSDATE";
  5. run;
  6. %MEND;
  7.  
  8. %show_result(BMW,SUV);

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

常用的宏

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

宏%PUT

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

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

宏%RETURN

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

  1. %macro check_condition(val);
  2. %if &val = 10 %then %return;
  3.  
  4. data p;
  5. x=34.2;
  6. run;
  7.  
  8. %mend check_condition;
  9.  
  10. %check_condition(11) ;
  11.  

宏%END

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

  1. %macro test(finish);
  2. %let i=1;
  3. %do %while (&i <&finish);
  4. %put the value of i is &i;
  5. %let i=%eval(&i+1);
  6. %end;
  7. %mend test;
  8. %test(5)
转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号