



版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、595380545.docSAS 系统和数据分析电子商务系列第十八课SAS 宏功能简介SAS 系统提供了强大的宏功能(macro facility ),通过创建宏变量和宏能方便地完成:重复分析任务,大大精减了程序量从系统获取一些如SAS 启动时间、日期、版本号等信息有条件地执行数据步和过程步保持程序的独立性和移植性,产生与数据无关的程序用宏变量在不同数据步和过程步之间传递数据一、 SAS宏变量宏变量(也称符号变量)属于 SAS 宏语言的范畴,和数据步中的变量概念是不一样的。除了数据行外,可以在 SAS 程序的任何地方定义和使用宏变量。数据步变量是和数据集相联系的,而宏变量是独立于数据集的。数据
2、集变量的值取决于正在处理的观测,而一个宏变量的值总是保持不变,直到被明确改变。1. 宏变量的定义定义一个宏变量的最简单方法是使用宏语句%LET ,它的一般形式如下:% LET宏变量名 =值;宏变量的命名遵从一般的 SAS 命名规则。宏变量的值不需要加引号,如果值加入引号,则引号被作为宏变量值的一部分。宏变量的值可以是固定的字符串、其他宏变量的引用、宏函数和宏调用。2. 宏变量的引用为了引用一个宏变量的值,在宏变量前加上一个符号& ,格式如下:& 宏变量名宏变量被引用的效果就是用宏变量的内容直接替代宏变量名。3. 宏变量的使用举例例如,我们想要打印、图示和分析几个数据集,但又希望
3、避免重复键入每一个数据集名字以修改相同的程序代码。解决方法是用%LET 语句创建一个宏变量DSNAME ,该宏变量赋上海财经大学经济信息管理系IS/SHUFECreated by zxdengPage 1 of 7595380545.docSAS 系统和数据分析电子商务系列值了一个数据集名SURVEY 。然后, 这个宏变量在PROC PRINT等许多过程和TITLE语句中被引用。程序如下:%Letdsname=survey ;Proc printVarTitledata=&dsname;namesexbdateincome“ Display of Data Set &dsnam
4、e;”Run ;要注意标题语句Title 平时既可以用单引号又可以用双引号围住标题,但如果有宏变量引用,则必须用双引号,否则用单引号将当作字符串处理。上面的程序中,我们只要修改宏变量 dsname 的赋值,就能对多个数据集执行相同的打印输出等操作。可用几个 %LET语句来创建多个宏变量进一步增强过程的通用性。例如,我们可用WHERE 语句来规定用作打印和分析的一个范围。如用%LET 语句把宏变量START 和 END分别定义为开始和结束的日期。程序如下:%Letdsname=survey ;%Letstart= 01jan79; d%Letend= 31dec80; dProc printda
5、ta=&dsname;Varname sex bdate income ;Where&start<bdate<&end ;Format bdate date7. ;Title “ Display of Data Set &dsname ;”Run ;这样,通过适当的 %LET 语句来简单改变起始和结束日期,就能替代在WHERE 语句中的多处改动。 提请大家注意宏变量赋值日期常数01jan79 d的这种格式, 也可以直接赋日期存储值,如改成 %Let start=6940和 %Let end=7670 。二、自动宏变量SAS 的宏变量共有两种:一是用户
6、定义的宏变量,如我们上面所定义的宏变量dsname、start、end。二是自动宏变量,由SAS 系统定义。自动宏变量是在系统启动时就已经被创建,在 SAS 系统退出前一直保持有效, 能够在 SAS系统的任何地方被引用。下表列出一些用户常用的自动宏变量:自动宏变量作用值SYSDATE本次 SAS 启动的日期如 04AUG97SYSDAY本次 SAS 启动的星期如 MondaySYSTIME本次 SAS 启动的时间如 11:18上海财经大学经济信息管理系IS/SHUFECreated by zxdengPage 2 of 7595380545.docSAS 系统和数据分析电子商务系列SYSLAS
7、T最新创建的数据集名字如 STUDY.SURVEYSYSDSN最新创建的数据集两部分名字如 STUDYSURVEYSYSVER使用 SAS 软件的版本如 6.12SYSSCP返回用户主机系统的缩写如 WIN例如,我们修改上面的程序,增加一个小标题,在小标题中引用自动宏变量,程序如下:%Letdsname=survey ;%Letstart= 01jan79; d%Letend= 31dec80; d%Letanalyst= Zuxin.Deng ;Proc printdata=&dsname;Varnamesexbdateincome;Where&start<bdate&
8、lt;&end;Format bdate date7.;Title“ Display of Data Set &dsname ;”Title 2“ &systime &sysday , &sysdate by &analyst;”Run ;三、创建一个宏宏是一个被存储的文本,用一个名字识别它。最简单的宏就像一个宏变量一样工作,但复杂的宏可以包括分支和循环等结构,能实现许多宏变量不能实现的功能。1. 宏的定义和调用宏定义的一般形式如下:%MACRO宏名字(参数宏变量);宏实体;%MEND宏名字;%MACRO语句是每一个宏的开始,同时必须给出这个宏的
9、名字。宏实体可为任一个文本, SAS 语句或 SAS 步,宏变量、函数和这些实体的组合。 %MEND 语句必须围住每个宏并表示宏结束。参数宏变量是一些将要传递给宏调用的宏变量,不同参数宏变量之间用逗号隔开。SAS 程序中可以包括任意多个宏,且在程序中可以多次调用一个宏。在SAS中引用宏调用的形式如下:上海财经大学经济信息管理系IS/SHUFECreated by zxdengPage 3 of 7595380545.docSAS 系统和数据分析电子商务系列%宏名字(参数值);例如,我们定义了一个简单通用的宏程序INVOKE ,它有两个参数宏变量procname 和dsname,用以传递给宏程序
10、所需的过程名和数据集名。在调用这个宏程序时要将具体的参数宏变量值给出,其值分别为 Print 和 Study.Survey。程序如下:%MACROINVOKE (procname, dsname);Proc&procnameData=&dsnmae;Title“ &procname of Data Set &dsname;”Run ;%MENDINVOKE;%INVOKE(Print , Study.survey);上面这段程序在执行时,将被宏处理器替换成下面这段程序:ProcPrintData=Study.survey;Title“ Print of Data
11、 Set Study.survey ;”Run ;2. 具有分支和循环的宏与 SAS 系统 DATA 步和 PROC 步中可以使用分支和循环语句一样,也能在%MACRO和%MEND 语句间,用条件%IF%THEN/%ELSE 语句和用循环%DO %END 、 %DO %UNTIL %END 、 %DO %WHILE %END 语句来产生更复杂的宏。虽然分支和循环的语句格式两者不相同,但两者的使用原理和方法却是相同的。通常SAS 宏程序比一般的SAS 语言程序要更难理解,主要的难点是宏程序中宏变量的传递和控制。例如,假设我们已有两个宏CREATE 和 PRINT ,宏 CREATE 可以从参数宏
12、变量SETDATA1指定的数据集中创建一个新的数据集STUDY.TEMP ,宏PRINT可以打印一个参数宏变量SETDATA2 指定的数据集。现在我们要定义一个控制宏CONTROL ,假定有时需要对指定的数据集先运行宏CREATE ,创建一个新的数据集STUDY.TEMP 后,再调用宏CREATE 打印这个新产生的数据集;有时却只要直接打印指定的数据集。那么,我们可以用一个%IF%THEN 语句来定义宏CONTROL 。程序如下:%Macrocreate(setname1) ;Datastudy.temp;Set&setname1 ;Ifsex='M' ;% Let d
13、sname=study.temp ;Run ;上海财经大学经济信息管理系IS/SHUFECreated by zxdengPage 4 of 7595380545.docSAS 系统和数据分析电子商务系列%Mendcreate;%Macroprint (setname2);Procprint data=&setname2;Title"Display of Data Set &setname2 "Run ;%Mendprint ;%Macro control(getdata,dsname) ;%If %upcase(&getdata)=YES %The
14、n %create(&dsname) ; %print (&dsname) ;%Mend control;%control (no, study.survey) ;%control (yes,study.survey) ;当规定参数宏变量getdata 的值为大写字符串YES 或小写字符串yes 时, %IF 条件成立,宏处理器执行 %THEN 的分句, 即调用宏 %create(&dsname) 。宏函数 %upcase的作用是转化小写文本为大写, 因此当 getdata 的值为小写字符串 yes 时,%IF 条件也成立。 在调用宏 %create时 要 给 出 参
15、数 宏 变 量 setname1 的 值 , 使 用 宏 变 量 &dsname 中 的 值 , 其 值 为 字 符 串 study.survey 。当规定参数宏变量getdata 的值为字符串YES 或 yes 以外的任何值时,%IF 条件不成立,执行调用宏 %print(&dsname) 。提请注意的是,即使%IF 条件成立,执行完%THEN 分句后,也同样要执行调用宏%print(&dsname) ,但打印的数据集不同。因此调用宏 %print(setname2)执行时,参数宏变量setname2 中的值有两种可能:当%IF条件成立,执行完宏%create 后,再
16、执行宏%print(setname2)时, setname2 中的值应该为study.temp;当 %IF 条件不成立,直接执行宏%print(setname2)时, setname2 中的值应该为study.survey。正因为有如此要求,所以要在宏%create 中增加一条 %Letdsname=study.temp语句,只要执行了宏%create 就修改宏变量dsname 的值为新建数据集名study.temp 。下面我们举一个宏循环语句的使用例子。假定用户想生成一系列变量名字用于某个SAS语句,如用在DATA 、 VAR 和 TITLE语句中。可以定义一个宏names 来产生具有相同前
17、缀的一系列变量名字。我们可采用重复%DO 循环语句来实现。程序如下:%MACROnamesvarname, number);(%Don=1%to &number ;&varname &n%Run;%MENDnames ;Proc printdata=study.class;Varname %names(Test, 3) ;Title“ %names(Test, 3) generated by macro variable ;”上海财经大学经济信息管理系IS/SHUFECreated by zxdengPage 5 of 7595380545.docSAS 系统和数据分析
18、电子商务系列Run ;第十九课 在数据集 STUDY .CLASS 中,有一组相同前缀 TEST和数字 1、2、 3 组成的字段变量名。打印过程 PROC PRINT中,采用调宏程序 %names(Test,3)来为 VAR语句指定分析变量TEST1、 TEST2 和TEST3 。宏程序 %names(Test,3)同样可以在 TITLE 语句的双引号中使用。提请注意,在宏程序 %names 中,&varname &n 语句的后面不应该有分号(; )。SAS 系统的图形功能简介SAS 系统强大的的图形功能主要由SAS/GRAPH软件模块的PLOT 图形过程和CHART图表过程实
19、现。 SAS/GRAPH 模块提供了许多产生图形的过程,并且能在图形输出GRAPH 窗口中对产生的图形进行编辑。在绘制图表前,如何根据资料的性质和绘图的目的,从SAS 系统提供的众多图表中,正确地选用统计图同样是至关重要的。一、统计图的基本概念SAS 的统计图是用点、线、面、体来形象地表示数量资料的一种方式,目的是为了使用户能比直接看数据更方便、更直观地分析和发现问题,甚至还能揭示出数据中的内在规律进而可以推断和预测。当然,即使针对于同一个问题的同一张图表,不同的人根据各自的经验和学识也可能会作出不同的结论,有时还需要组合各种图表进行综合分析。常用的统计图有散布图、折线图、条形图、直方图、圆饼
20、图、统计地图等。二、图形表示方法的选择一般来说,借助于计算机的决策支持系统的最终输出结果总是以图表形式居多。然后根据图表进行决策和预测。 显然看图表进行决策和预测比直接看数据要容易和方便得多。 但是,一组结果数据却可以绘制出各种各样的图表,许多图表并没有什么意义。如何根据结果数据所要分析的问题,正确地选用统计图并非是件容易的事,它也是整个分析决策中的一部分。上海财经大学经济信息管理系IS/SHUFECreated by zxdengPage 6 of 7595380545.docSAS 系统和数据分析电子商务系列例如,在股票技术分析中,有许多经过计算机画好的技术统计图表,一个有经验的技术分析者
21、首先要能对不同的分析目的正确地选用不同的技术统计图表,如要分析股票的中长期趋势,选用中长期的移动平均线等;要分析股票的强和弱,选用相对强弱指标RSI 等;要分析股票的短期交易信号,选用随机指标KDJ 等。用计算机绘制出统计图其实并不难, SAS 软件也一样。但现在许多计算机软件都无法自动根据资料选择输出的图表。都需要人工干预输出或输出所有可能需要的图表。但人们还是总结出一些最基本的选用统计图的原则。1. 资料性质原则根据资料的类型和目的选用合适的统计图。资料的类型主要有两类:定性资料和定量资料。定性资料,可选用的统计图有条形图、圆饼图、统计地图等。定量资料,可选用的统计图有直方图、折线图、半对数图、散布图等。根据资料的目的选用统计图,最主要的还是要看具体的问题方可确定,如上面我们所举的股票技术分析的例子。2. 图形特征原则不同的统计图,以不同的角度或姿态来形象化地表达资料。因此,掌
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 工程结算考试题及答案
- 家具设计标准与行业规范的理解试题及答案
- 会昌教招面试真题及答案
- 数量与质的对比理解题试题及答案
- 2025临床医学笔试题目及答案
- 植物上场测试题及答案
- 2025公务员考试试题及答案
- 2025飞行员面试试题及答案
- 区块链跨境支付系统稳定性与可靠性研究报告
- 教师教学改进方向的试题及答案
- 2025专利代理师笔试考试题库带答案
- 第3课《校园文化活动我参与》教案 海燕版综合实践活动 三年级下册
- 2025年保密教育线上培训考试试题及答案
- 大学生职业规划大赛《运动康复专业》生涯发展展示
- 高楼遮光补偿协议书范本
- 课题申报书:生成式人工智能赋能高职教学变革研究
- 2025-2030专用车产业规划及发展研究报告
- 《自由现金流折现法对东鹏特饮公司的财务估值实例分析》2000字
- 2024年四川绵阳科技城新区招聘社区工作者考试真题
- 2025-2030中国甘蔗收割机行业市场现状供需分析及投资评估规划分析研究报告
- 二零二五简短美发店劳动合同
评论
0/150
提交评论