欢迎来到天天文库
浏览记录
ID:33907707
大小:86.00 KB
页数:6页
时间:2019-03-01
《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.cnPage6of67eb2
4、f74090b2dd2963762fef51df8646.docSAS系统和数据分析电子商务系列%Letdsname=survey;Procprintdata=&dsname;Varnamesexbdateincome;Title“DisplayofDataSet&dsname”;Run;要注意标题语句Title平时既可以用单引号又可以用双引号围住标题,但如果有宏变量引用,则必须用双引号,否则用单引号将当作字符串处理。上面的程序中,我们只要修改宏变量dsname的赋值,就能对多个数据集执行相同的打印输出等操作。
5、可用几个%LET语句来创建多个宏变量进一步增强过程的通用性。例如,我们可用WHERE语句来规定用作打印和分析的一个范围。如用%LET语句把宏变量START和END分别定义为开始和结束的日期。程序如下:%Letdsname=survey;%Letstart=’01jan79’d;%Letend=‘31dec80’d;Procprintdata=&dsname;Varnamesexbdateincome;Where&start6、DataSet&dsname”;Run;这样,通过适当的%LET语句来简单改变起始和结束日期,就能替代在WHERE语句中的多处改动。提请大家注意宏变量赋值日期常数’01jan79’d的这种格式,也可以直接赋日期存储值,如改成%Letstart=6940和%Letend=7670。一.自动宏变量SAS的宏变量共有两种:一是用户定义的宏变量,如我们上面所定义宏变量dsname、start、end。二是自动宏变量,由SAS系统定义。自动宏变量是在系统启动时就已经被创建,在SAS系统退出前一直保持有效,能够在SAS系统7、的任何地方被引用。下表列出一些用户常用的自动宏变量:自动宏变量作用值SYSDATE本次SAS启动的日期如04AUG97SYSDAY本次SAS启动的星期如MondaySYSTIME本次SAS启动的时间如11:18SYSLAST最新创建的数据集名字如STUDY.SURVEYSYSDSN最新创建的数据集两部分名字如STUDYSURVEY上海财经大学经济信息管理系IS/SHUFECreatedbyzxdeng@mail.shufe.edu.cnPage6of67eb2f74090b2dd2963762fef51df868、46.docSAS系统和数据分析电子商务系列SYSVER使用SAS软件的版本如6.12SYSSCP返回用户主机系统的缩写如WIN例如,我们修改上面的程序,增加一个小标题,在小标题中引用自动宏变量,程序如下:%Letdsname=survey;%Letstart=’01jan79’d;%Letend=‘31dec80’d;%Letanalyst=Zuxin.Deng;Procprintd
6、DataSet&dsname”;Run;这样,通过适当的%LET语句来简单改变起始和结束日期,就能替代在WHERE语句中的多处改动。提请大家注意宏变量赋值日期常数’01jan79’d的这种格式,也可以直接赋日期存储值,如改成%Letstart=6940和%Letend=7670。一.自动宏变量SAS的宏变量共有两种:一是用户定义的宏变量,如我们上面所定义宏变量dsname、start、end。二是自动宏变量,由SAS系统定义。自动宏变量是在系统启动时就已经被创建,在SAS系统退出前一直保持有效,能够在SAS系统
7、的任何地方被引用。下表列出一些用户常用的自动宏变量:自动宏变量作用值SYSDATE本次SAS启动的日期如04AUG97SYSDAY本次SAS启动的星期如MondaySYSTIME本次SAS启动的时间如11:18SYSLAST最新创建的数据集名字如STUDY.SURVEYSYSDSN最新创建的数据集两部分名字如STUDYSURVEY上海财经大学经济信息管理系IS/SHUFECreatedbyzxdeng@mail.shufe.edu.cnPage6of67eb2f74090b2dd2963762fef51df86
8、46.docSAS系统和数据分析电子商务系列SYSVER使用SAS软件的版本如6.12SYSSCP返回用户主机系统的缩写如WIN例如,我们修改上面的程序,增加一个小标题,在小标题中引用自动宏变量,程序如下:%Letdsname=survey;%Letstart=’01jan79’d;%Letend=‘31dec80’d;%Letanalyst=Zuxin.Deng;Procprintd
此文档下载收益归作者所有