欢迎来到天天文库
浏览记录
ID:6699036
大小:86.00 KB
页数:6页
时间:2018-01-22
《sas讲义 第十八课sas宏功能简介》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、7eb2f74090b2dd2963762fef51df8646.docSAS系统和数据分析电子商务系列第十八课SAS宏功能简介*SAS系统提供了强大的宏功能(macrofacility),通过创建宏变量和宏能方便地完成:l重复分析任务,大大精减了程序量l从系统获取一些如SAS启动时间、日期、版本号等信息l有条件地执行数据步和过程步l保持程序的对立性和移植性,产生与数据无关的程序l用宏变量在不同数据步和过程步之间传递数据一.SAS宏变量宏变量(也称符号变量)属于SAS宏语言的范畴,和数据步中的变量概念是不一样的。除了数据行外,可
2、以在SAS程序的任何地方定义和使用宏变量。数据步变量是和数据集相联系的,而宏变量是独立于数据集的。数据集变量的值取决于正在处理的观测,而一个宏变量的值总是保持不变,直到被明确改变。1宏变量的定义定义一个宏变量的最简单方法是使用宏语句%LET,它的一般形式如下:%LET宏变量名=值;宏变量的命名遵从一般的SAS命名规则。宏变量的值不需要加引号,如果值加入引号,则引号被作为宏变量值的一部分。宏变量的值可以是固定的字符串、其它宏变量的引用、宏函数和宏调用。2宏变量的引用为了引用一个宏变量的值,在宏变量前加上一个符号&,格式如下:&宏变
3、量名宏变量被引用的效果就是用宏变量的内容直接替代宏变量名。3宏变量的使用举例例如,我们想要打印、图示和分析几个数据集,但又希望避免重复键入每一个数据集名字以修改相同的程序代码。解决方法是用%LET语句创建一个宏变量DSNAME,该宏变量赋值了一个数据集名SURVEY。然后这个宏变量在PROCPRINT等许多过程和TITLE语句中被引用。程序如下:上海财经大学经济信息管理系IS/SHUFECreatedbyzxdeng@mail.shufe.edu.cnPage6of67eb2f74090b2dd2963762fef51df864
4、6.docSAS系统和数据分析电子商务系列%Letdsname=survey;Procprintdata=&dsname;Varnamesexbdateincome;Title“DisplayofDataSet&dsname”;Run;要注意标题语句Title平时既可以用单引号又可以用双引号围住标题,但如果有宏变量引用,则必须用双引号,否则用单引号将当作字符串处理。上面的程序中,我们只要修改宏变量dsname的赋值,就能对多个数据集执行相同的打印输出等操作。可用几个%LET语句来创建多个宏变量进一步增强过程的通用性。例如,我们可
5、用WHERE语句来规定用作打印和分析的一个范围。如用%LET语句把宏变量START和END分别定义为开始和结束的日期。程序如下:%Letdsname=survey;%Letstart=’01jan79’d;%Letend=‘31dec80’d;Procprintdata=&dsname;Varnamesexbdateincome;Where&start6、期,就能替代在WHERE语句中的多处改动。提请大家注意宏变量赋值日期常数’01jan79’d的这种格式,也可以直接赋日期存储值,如改成%Letstart=6940和%Letend=7670。一.自动宏变量SAS的宏变量共有两种:一是用户定义的宏变量,如我们上面所定义宏变量dsname、start、end。二是自动宏变量,由SAS系统定义。自动宏变量是在系统启动时就已经被创建,在SAS系统退出前一直保持有效,能够在SAS系统的任何地方被引用。下表列出一些用户常用的自动宏变量:自动宏变量作用值SYSDATE本次SAS启动的日期如047、AUG97SYSDAY本次SAS启动的星期如MondaySYSTIME本次SAS启动的时间如11:18SYSLAST最新创建的数据集名字如STUDY.SURVEYSYSDSN最新创建的数据集两部分名字如STUDYSURVEY上海财经大学经济信息管理系IS/SHUFECreatedbyzxdeng@mail.shufe.edu.cnPage6of67eb2f74090b2dd2963762fef51df8646.docSAS系统和数据分析电子商务系列SYSVER使用SAS软件的版本如6.12SYSSCP返回用户主机系统的缩写如WI8、N例如,我们修改上面的程序,增加一个小标题,在小标题中引用自动宏变量,程序如下:%Letdsname=survey;%Letstart=’01jan79’d;%Letend=‘31dec80’d;%Letanalyst=Zuxin.Deng;Procprintd
6、期,就能替代在WHERE语句中的多处改动。提请大家注意宏变量赋值日期常数’01jan79’d的这种格式,也可以直接赋日期存储值,如改成%Letstart=6940和%Letend=7670。一.自动宏变量SAS的宏变量共有两种:一是用户定义的宏变量,如我们上面所定义宏变量dsname、start、end。二是自动宏变量,由SAS系统定义。自动宏变量是在系统启动时就已经被创建,在SAS系统退出前一直保持有效,能够在SAS系统的任何地方被引用。下表列出一些用户常用的自动宏变量:自动宏变量作用值SYSDATE本次SAS启动的日期如04
7、AUG97SYSDAY本次SAS启动的星期如MondaySYSTIME本次SAS启动的时间如11:18SYSLAST最新创建的数据集名字如STUDY.SURVEYSYSDSN最新创建的数据集两部分名字如STUDYSURVEY上海财经大学经济信息管理系IS/SHUFECreatedbyzxdeng@mail.shufe.edu.cnPage6of67eb2f74090b2dd2963762fef51df8646.docSAS系统和数据分析电子商务系列SYSVER使用SAS软件的版本如6.12SYSSCP返回用户主机系统的缩写如WI
8、N例如,我们修改上面的程序,增加一个小标题,在小标题中引用自动宏变量,程序如下:%Letdsname=survey;%Letstart=’01jan79’d;%Letend=‘31dec80’d;%Letanalyst=Zuxin.Deng;Procprintd
此文档下载收益归作者所有