第10章 SAS宏功能
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第10章SAS宏功能
10.1 概述
SAS系统的MACRO处理器可以让程序更简洁更明了及更容易维护,帮助用户在使用SAS系统时更方便更自动化,具体来说,它具有以下功能:1.获取SAS的系统信息;
2.有条件地执行数据步和过程步;
3.开发交互式系统;
4.在不同的数据步和过程步之间传递数据;
5.重复执行SAS代码
等等。.
SAS宏语言的管理
1.MACRO变量
2.MACRO程序语句
3.MACRO表达式和函数
10.2 SAS宏变量的使用与定义
宏变量(有时也称符号变量)属于SAS宏语言的范畴,和数据步中的变量的概念是不一样的。除了数据行外,你可以在SAS程序的任何地方定义和使用宏变量。数据步变量是和数据集相联系的,而宏变量是独立于数据集的。数据集变量的值取决于正在处理的观测,而一个宏变量的值总是不变,直到被明确改变。宏变量类似于一般变量的命名方法。程序中以&宏名来引用MACRO变量(有时为了清晰起见,也可以通过&宏名. 来引用MACRO变量)
SAS宏变量共有两种:
1.系统宏变量
2.用户自定义的宏变量。
10.2.1 系统宏变量 一些系统宏变量
01 /* Program_10-l-l.sas */
02 DA TA _NULL_;
03 PUT 'SYSDATE=' "&SYSDA TE"; /* 执行时的日期 */
04 PUT 'SYSDAY='"&SYSDAY"; /* 执行时是星期几 */
05 PUT 'SYSENV='"&SYSENV"; /* 交互模式或批次模式 */
06 PUT 'SYSSCP='"&SYSSCP"; /* 返回正在用的操作系统 */
07 PUT 'SYSJOBID = '"&SYSJOBID"; /* 程序的操作执行代码 */
08 PUT 'SYSERR='"&SYSERR"; /* 程序执行的错误码 */ 09 PUT 'SYSRC='"&SYSRC";
/*程序执行的回复码 */ 10 PUT 'SYSLIBRC='"&SYSLIBRC"; /* 使用LIBNAME 时设置是否正确 */
11 PUT 'SYSFILRC='"&SYSFILRC"; /*使用FILENAME 时设置是否正确*/
12 RUN;
使用宏语句 %put _automatic_; 可以查看所有的系统宏变量,结果显示在LOG
窗口。
SYSDATE=20OCT08
SYSDAY=Wednesday
SYSENV=FORE
SYSSCP=WIN
SYSJOBID = 384
SYSERR=0
SYSRC=0
SYSLIBRC=0
SYSFILRC=0
NOTE: DATA statement used:
real time 0.03 seconds
cpu time 0.01 seconds
10.2.2 用户自定义宏变量
定义方法及其使用: %LET mac_var=取值 等号左边是宏名.定义好的MACRO 变量可以在不同的SAS 数据步或过程步
中重复使用,该MACRO 变量的值不会改变. 引用时直接用&宏名. 即可. 宏变
量定义可以放在程序的任何位置,但在使用之前一定要定义好.
例1
01 /* Programs10-2-l.sas */
02 %LET mm=07;
03 DATA outl;
04 FORMAT var_a YYMMDD10.;
05 INPUT var_a :YYMMDD6.;
06 IF month(var_a)= &mm;
07 DATALINES;
08 010203
09 010721
10 010322
11 010723
12 010103
13 010402
14 ;
16 PROC PRINT;
17 TITLE "数据月份:&mm";
18 RUN;
注:这里的标题必须用双引号括起来,而不能用单引号,因为宏处理器只对双引号中引用的宏变量进行这种处理,而把单引号中的所有字符都看作是标题的内容。
结果:
数据月份:07 07:57 Wednesday, October 20, 2008 2
Obs var_a
1 2001-07-21
2 2001-07-23
注:如果要查看用户自定义的宏变量,可以提交语句%put _USER_;
如果要查看所有宏变量,可以提交语句%put _ALL_;
可将SAS的一段程序设为MACRO变量
例2 一个宏变量代表一行语句时
01 /* Program_10-2-3.Sas */
02 %LET mm = INPUT var_a :YYMMDD6.;
03 DATA outl;
04 FORMAT var_a YYMMDD10.;
05 &mm;
06 DATALINES;
07 010203
08 010721
09 010322
10 010723
11 010103
12 010402
13 ;
14 RUN ;
一些宏函数
1)宏函数%str
例3 一个宏变量代表多行语句时,可用宏函数%str来实现
01 /* Program_10-2-3_2.sas */
02 DATA out1;
03 INPUT Income Age;
04 DATALINEs;
05 1500 23
06 2600 35
07 2000 28
08 3000 30
09 1800 19
10 ;
11 run;
12 %let dsn=out1;
13 %let yvar=Income;
14 %let xvar=Age;
15 %let plot=%str(Proc plot;plot &yvar*&xvar;run;); /*宏变量也可以嵌套引用*/
16 DATA temp;
17 set &dsn;
18 if Age>=20;
19 &plot;
20 Proc print;
21 Title subsetof &dsn;
22 run;
SAS数据步有关的一些宏函数
2)宏函数%EV AL:当表达式中数字为整数时,把表达式转化为具体数值赋给宏变量。如果表达式中数字不是整数,使用函数%sysevalf(表达式)。
例4
%let m1=10/2;
data aaa;
x=&m1;
proc print;
run;