




已阅读5页,还剩40页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
SASMACRO简介,西南财经大学统计学院,目标,使用系统(或自动的)macro变量创建和使用用户定义的macro变量定义和调用macro程序块定义和调用带参数的macro程序块Macro程序块的if、do使用,SASMacro语言,用于字符串操作的第二SAS编程语言,使用系统macro变量,问题:PROCPRINTDATA=DEPTSALE;TITLE“到#的部门销售额”;RUN;你想让今天的年月日和星期几显示在Title里,用SAS怎么做?答案:使用系统macro变量.,PROCPRINTDATA=DEPTSALE;TITLE“到注意:Macro变量不能在单引号内被解释.,到26MAY07的部门销售额OBSDEPTYEARSALARIESSALES1187100010002188100020003287500300042886002000,使用系统macro变量,SAS系统自带的Macro变量,Apartiallistofautomaticmacrovariablesandtheirusage:SYSBUFFRtextenteredinresponseto%INPUTSYSCMDlastnon-SAScommandenteredSYSDATEcurrentdateinDATE6.orDATE7.formatSYSDAYcurrentdayoftheweekSYSDEVICcurrentgraphicsdeviceSYSDSNlastSASdatasetbuilt(i.e.,WORKSOFTSALE)SYSENVSASenvironment(FOREorBACK)SYSERRreturncodesetbySASproceduresSYSFILRCwhetherlastFILENAMEexecutedcorrectlySYSINDEXnumberofmacrosstartedinjobSYSINFOsysteminformationgivenbysomePROCSSYSJOBIDnameofexecutingjoboruserSYSLASTlastSASdatasetbuilt(i.e.,WORK.SOFTSALE)SYSLIBRCreturncodefromlastLIBNAMEstatementSYSLCKRCwhethermostrecentlockwassuccessful,SAS自带的Macro变量,SYSMENVmacroexecutionenvironmentSYSMSGmessagedisplayedwith%DISPLAYSYSPARMvaluepassedfromSYSPARMinJCLSYSPRODindicateswhetheraSASproductislicensedSYSPBUFFallmacroparameterspassedSYSRCreturncodefrommacroprocessorSYSSCPoperatingsystemwhereSASisrunningSYSTIMEstartingtimeofjobSYSVERSASversionExample:FOOTNOTETHISREPORTWASRUNON,显示Macro变量,%PUT在编译程序时把macro变量显示在log窗口里.语法:%PUTtextmacrovariables;%PUT_all_;举例:%PUT*PartialSASLog:*26MAR07*,显示所有的Macro变量,%PUT可以显示所有的Macro变量,方法为:%PUT_ALL_;PartialSASLog:GLOBALMBILLYR99GLOBALSSCDEVCAUTOMATICAFDSID0AUTOMATICAFDSNAMEAUTOMATICAFLIBAUTOMATICAFSTR1AUTOMATICAFSTR2AUTOMATICFSPBDVAUTOMATICSYSBUFFRAUTOMATICSYSCMDAUTOMATICSYSDAYTuesday,练习,练习1:使用你目前的计算机系统决定以下系统Macro变量的值.INPUTEMP$RATE;DATALINES;TOM10JIM10;PROCPRINTDATA=PAYROLL;TITLEPRINTOFDATASETPAYROLL;RUN;如何只在一个地方改动名字,并且让数据集合名称出现在标题中?解答:使用Macro变量.,创建和使用用户定义的macro变量,用%LET定义变量.然后用,创建和使用用户定义的macro变量,DATAPAYROLL;INPUTEMP$RATE;DATALINES;TOM10JIM10;PROCPRINTDATA=PAYROLL;TITLEPRINTOFDATASETPAYROLL;RUN;Notes:Macrovariablesarenotresolvedwithinsinglequotes.,创建和使用用户定义的macro变量,用%LET另赋一个值.%LETNAME=NEWPAY;DATA,创建和使用用户定义的macro变量,DATANEWPAY;INPUTEMP$RATE;DATALINES;TOM10JIM10;PROCPRINTDATA=NEWPAY;TITLEPRINTOFDATASETNEWPAY;RUN;,创建和使用用户定义的macro变量,赋几个SAS语句:%STR可允许“;”等出现在命令之间.%LETNAME=NEWPAY;%LETCHART=%STR(PROCCHART;VBAREMP;RUN;);DATA,创建和使用用户定义的macro变量,DATANEWPAY;INPUTEMP$RATE;DATALINES;TOM10JIM10;PROCCHART;VBAREMP;RUN;PROCPRINTDATA=NEWPAY;TITLEPRINTOFDATASETNEWPAY;RUN;,创建和使用用户定义的macro变量,Macro变量可以包含其它的Macro变量%LETNAME=NEWPAY;%LETCHART=%STR(PROCCHARTDATA=,创建和使用用户定义的macro变量,DATANEWPAY;INPUTEMP$RATE;DATALINES;TOM10JIM10;PROCCHARTDATA=NEWPAY;VBAREMP;RUN;PROCPRINTDATA=NEWPAY;TITLEPRINTOFDATASETNEWPAY;RUN;,练习,做法:把你的答案写在纸上.用%PUT语句检验你的答案.练习3:在执行完以下的%LET语句之后%LETA=ANDY;%LETB=1999;%LETC=CANES;%LETD=DECEMBER31,;%LETE=TREMENDOUS;,练习3(continued),这些%PUT语句的输出结果是什么?%PUT,练习3解答,%LETA=ANDY;%LETB=1999;%LETC=CANES;%LETD=DECEMBER31,;%LETE=TREMENDOUS;,练习3解答,%PUT1999WASATREMENDOUSSALESYEAR!,定义和调用macro程序块,%MACRO和%MEND定义macro.使用%macroname调用Macro.例子:定义一个macro运行PROCCHART,然后调用%MACROCHART;PROCCHARTDATA=,定义和调用macro程序块,%LETNAME=NEWPAY;DATA,定义和调用macro程序块,DATANEWPAY;INPUTEMP$RATE;DATALINES;TOM10JIM10;RUN;PROCCHARTDATA=NEWPAY;VBAREMP;RUN;PROCPRINTDATA=NEWPAY;TITLEPRINTOFDATASETNEWPAY;RUN;,练习4,以下是一个Macro定义:%MACROFREQ;PROCFREQDATA=%FREQ,练习4解答,PROCFREQDATA=FREQ;TITLEEXERCISE5;TABLESDEPT*SALES/NOPERCENT;RUN;,练习4输出,定义和调用带参数的Macro程序块,Macro参数定义在macro名称的后面。%MACROCHART(NAME,BARVAR);PROCCHARTDATA=,定义和调用带参数的Macro程序块,Macro调用其它Macro.%MACROCHART(NAME,BARVAR);PROCCHARTDATA=%PTCHART(PAYROLL,EMP),定义和调用带参数的Macro程序块,PROCCHARTDATA=PAYROLL;VBAREMP;RUN;PROCPRINTDATA=PAYROLL;TITLEPRINTOFDATASETPAYROLL;RUN;,Macro程序块的if、do使用,%IF可以设置条件,代码只有在满足该条件时才能被送到编译器举例:只有在PRTCH=YES时RunPROCPRINT.%MACROPTCHT(PRTCH,NAME,BARVAR);%IF%PTCHT(YES,PAYROLL,EMP),Macro程序块的if、do使用,PROCPRINTDATA=PAYROLL;PROCCHARTDATA=PAYROLL;VBAREMP;RUN;,Macro程序块的if、do使用,%DO可以使得多个语句被编译.举例:和前例相同,但多加了一个标题.%MACROPTCHT(PRTCH,NAME,BARVAR);%IF%PTCHT(YES,PAYROLL,EMP),Macro程序块的if、do使用,PROCPRINTDATA=PAYROLL;TITLEPRINTOFDATASETPAYROLL;RUN;PROCCHARTDATA=PAYROLL;VBAREMP;RUN;,Macro程序块的if、do使用,举例:多次运行PROCPRINT,运行次数由Macro参数决定%MACROPRTMAC(PRTNUM,NAME);%DOI=1%TO%PRTMAC(4,PAYROLL),Macro程序块的if、do使用,PROCPRINTDATA=PAYROLL1;TITLEPRINTOFDATASETPAYROLL1;RUN;PROCPRINTDATA=PAYROLL2;TITLEPRINTOFDATASETPAYROLL2;RUN;PROCPRINTDATA=PAYROLL3;TITLEPRINTOFDATASETPAYROLL3;RUN;PROCPRINTDATA=P
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年PAC管桩行业深度研究报告
- 阳光学院《急救与灾难应变》2023-2024学年第二学期期末试卷
- 柳州铁道职业技术学院《金融应用程序设计》2023-2024学年第二学期期末试卷
- 河南女子职业学院《学前儿童社会教学法》2023-2024学年第二学期期末试卷
- 江西工程职业学院《计算机建模技术》2023-2024学年第二学期期末试卷
- 2025-2030年中国玻璃钢水箱行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030年中国物联网操作系统行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030年中国焊接通风产品行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030年中国氢电解槽行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030年中国槽钢行业市场现状供需分析及投资评估规划分析研究报告
- 2025年版村规民约
- 沙特阿拉伯商务谈判风格礼仪与禁忌
- 2025年起重装卸机械操作工(天车)职业技能理论考试题库-上(单选题)
- 2025年中国足球俱乐部行业市场调研分析及投资战略咨询报告
- DBJ50-T-078-2016重庆市城市道路工程施工质量验收规范
- 医师人员管理制度内容
- 周转轮系传动比计算实例机械设计基础课件讲解
- 弱电项目安全施工应急预案(3篇)
- 【MOOC】信号与系统-南京邮电大学 中国大学慕课MOOC答案
- DB32T 2334.4-2013 水利工程施工质量检验与评定规范 第4部分 电气设备与自动化
- 导尿术课件完整版
评论
0/150
提交评论