已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 26年西药一考试试题及答案
- 少儿2025年机器人编程竞赛培训合同
- 商业秘密保护咨询2025年合同协议
- 院内血糖管理优化
- 2025年陕西华山建设集团有限公司选聘真题
- 2025年潍坊市奎文区招聘事业编教师考试真题
- 2025年荆州市定向招聘大学生村级后备干部考试真题
- 《数控加工编程与操作2》课件-4.2.1千斤顶产品装配
- 2026年昌吉市林业系统事业单位人员招聘考试备考试题及答案详解
- 2026北京中医药大学东方医院应届毕业生及出站博士后招聘11人(第五批)笔试备考试题及答案解析
- DZ∕T 0213-2020 矿产地质勘查规范 石灰岩、水泥配料类(正式版)
- 《欣赏建筑之美》参考课件
- 围术期喉痉挛处理
- TN-HDB-0006-HANA中SDA的配置与应用-v0.8
- 龙湖集团工程管理手册
- 生物药剂学与药物动力学复习重点总结
- 榆阳区可可盖煤矿矿山地质环境保护与土地复垦方案
- 部编版四年级道德与法治下册第7课《我们的衣食之源》优质课件(第2课时)
- 苏科版二年级下册劳动第8课《杯套》课件
- GB/T 23510-2009车用燃料甲醇
- 医院产前筛查中心设置评审验收工作汇报课件
评论
0/150
提交评论