当程序较长的时侯,就象上面 的程序一样,总是使用%LET 语句就显得不那么方便了,这时可以使用宏参数, 即定义宏 变量作 为%MACRO 语句的一部分。 %MACRO plot(yvar,xvar); PROC PLOT; PLOT &yvar*&xvar; RUN; %MEND plot; %MACRO 语句的括号中定义的宏变量就是宏参数,当调用宏的时侯,需将值传递给宏参 数, 如: %plot(income,age) 宏处理器把第 1 个值和第 1 个宏变量匹配,第 2 个值和第 2 个宏变量匹配……因此,这些 参数 叫做位置参数,于是产生下面语句: PROC PLOT; PLOT INCOME*AGE; RUN; 假设你经常创建数据集 TEMP 和绘制 PLOT 图,你可以将数据步做成一个宏,而过程步做 成另 一个宏,然后在第 3 个宏里调用它们。注意最好加上注释说明你要做什么。 %MACRO create; %MACRO analyze(yvar,xvar);
Data temp; %*Create the Data Set; SET olddata; IF age>=20; %create %MEND create; %*Plot the Variable Selected; %MACRO plot; %plot PROC plot; %MEND analyze; PLOT &yvar*&xvar; RUN; %MEND plot; (程序的第1部分) (程序的第2部分) 在宏 ANALYZE 中,由“%*”开始的语句是宏注释语句, 它们用于对宏内做的事情作注解。 当宏较长的时侯,是很必要的。当你定义完这些宏后,就可以通过调用宏来运行程序。 %analyze(income,age) 如果你想改变 CREATE,重新定义它,则: %MACRO create; DATA temp2; SET olddata(obs=100); IF age>=20; %MEND create; 然后调用 ANALYZE,方法是: %analyze(income,age) 当然,你也可以把整个程序段都放入 ANALYZE,而不去调用其他宏,但是,定义 CREATE 和 PLOT 的优点是你可以在调用 ANALYZE 之前分别重新定义和调试它们,在规模较大的宏中, 模 块结构 是很重要的。 当你使用宏 ANALYZE 时,假设有时你需要执行宏 CREATE 中的 DATA 步,而有时又可直 接从 PROC PLOT 开始,重新定义 ANALYZE,使用%IF-%THEN 语句。 %MACRO analyze(getdata,yvar,xvar); %IF &getdata=yes %THEN %create; %ELSE %plot; %MEND analyze; 如下调用 ANALYZE,方法为: %analyze(yes,income,age) %analyze(no,income,yrs_educ)产生:
DATA TEMP; SET OLDDATA; IF AGE>=20; PROC PLOT; PLOT INCOM
E*AGE; RUN; PROC PLOT; PLOT INCOME*YRS_EDUC; RUN; 如果在%THEN 从句中有多个语句, 使用%DO-%END 组,如: %MACRO analyze(getdata,yvar,xvar); TITLE; %IF &getdata=yes %THEN %DO; %create TITLE3 "Data Set Created for This Plot"; %END; %plot %MEND analyze; 如果我们调用 ANALYZE, 方法如下: %analyze(YES,income,age) 。 那么产生的语句是: “PROC PLOT; PLOT INCOME*AGE; RUN; ”。 宏处理器并没有调用宏 CREATE 去创建一个数据集, 因为宏处理器在把宏展开时并不 把小 写字母转换为大写。于是%IF 语句作的比较是 YES=yes,当然为假,事与愿违。为了在调
用时不 管大小写都正确,应该修改 ANALYZE 如下: %MACRO analyze(getdata,yvar,xvar); %IF %UPCASE(&getdata)=YES %THEN %create; %ELSE %plot; %MEND analyze; 其中宏函数%UPCASE 把小写转换为大写。 假设你想创建一系列名字用于 SAS 语句, 如 DATA 或 VAR 语句,可以借助宏来实现。 %MACRO names(name,number) %DO n=1 %TO &number; &name&n %END; %MEND names; 宏 NAMES 把参数 NAME 的值和宏变量的值连接起来形成一系列名字,参数 NUMBER 的 值是宏变 量 N 的终止值。于是在 DATA 步中调用 NAMES,方法如下: DATA %names(dsn,5); 产生语句: DATA DSN1 DSN2 DSN3 DSN4 DSN5; 3. 数据步中的宏变量 假设你想把一个数据集的观测数放进一个 FOOTNOTE 语句中,首先定义一个宏,如: %MACRO create; DATA temp; SET olddata END=final; IF age>=20 THEN DO; n+1; OUTPUT; END; IF final THEN CALL SYMPUT('number',n); RUN; %MEND create; 以后一旦调用 CREATE,则 CALL SYMPUT 语句将计数变量 N 的值传递给宏变量 NUMBER,NUMBER 可以是以前创建的宏变量,也可以是在当前的 DATA 步创建的。 这个宏变量以后可以直接引用, 也可以在 DATA 步用 SYMGET 函数引用。 从而实匣同的 数 据步中的值传递,如: x=SYMGET('number'); 数据步变量 X 的值就是数据集 TEMP 中的观测个数。 也可以在 DATA 步用 SYMGET 函数引用。从而实匣同的数 据步中的值传递,如: x=SYMGET('number'); 数据步变量 X 的值就是数据集 TEMP 中的观测个数。
数据分析咨询请扫描二维码
CDA数据分析师在中国航信高科技产业园进行了面向测试度量的数据分析培训课程,培训人数近2 ...
2024-05-01CDA数据分析师走进深圳迈瑞生物医疗电子股份有限公司,在迈瑞总部展开了为期两天的培训,本次课程参训人员线上及线下近百人, ...
2024-05-01CDA数据分析师在合肥市对合肥阳光新能源科技有限公司开展了为期8天的企业内训。 合肥阳光新能源科技 ...
2024-05-01CDA数据分析师走进海尔大学,进行了《数据治理与数据中台建设的道与术》专题培训,培训现场爆满,近百人参加了此次培训。 ...
2024-05-01在中国银行苏州分行培训中心开始数据分析师培训,此次培训课程共10天内容,包括Excel、MySQL、概率论与数理统计、SPSS等内容, ...
2024-05-01从实际的业务需求出发,结合行业的典型应用特点,围绕实际的商业问题,探讨数据挖掘、机器学习模型在金融领域的应用,包括获客、信用评分、细分画像、交叉销售、反欺诈、违规识别、时序预测、运筹优化、流程挖掘九个方面,形成 ...
2024-05-01本次培训课程为线上+线下的模式,由于学员编程能力不一、部分学员没有编程基础,故提供统计学、python基 ...
2024-05-01华夏银行信用卡中心-机器学习培训 1、课程亮点 取材于业界一流企业和顶级咨询公司的行业实践;已经被证明是人人 ...
2024-05-01主 题:数据中台建设及数据分析应用主题分享 1. 数据中台市场洞察 2. 主流数据中台产品比较 3. 某企业数据中 ...
2024-05-01围绕“数据驱动”战略,全力打造我行 300 人数字化人才梯队,着力培养数字化管理人才、大数据专业团队 ...
2024-05-01在当今数据驱动的商业环境中,数据分析成为了企业决策的重要依据。通过对大量数据的收集、处理和分析,企业能够更好地理解市场 ...
2024-04-29在人工智能(AI)的世界里,提示词(Prompt)是一种强大的工具,它能够引导AI按照用户的需求产生特定的输出。本文将深入探讨AI ...
2024-04-29CDA立足未来职场,拓展前沿视野——对外经贸大学保险学院举办“三全育人大讲堂”分享行业最新动态。 ...
2024-04-294月2日,CDA数据分析师创始发起人兼协会理事长赵坚毅博士受邀在浙江万里学院举办了一场以“数字化能力在职场中的作用” ...
2024-04-29随机森林(Random Forests)现在机器学习中比较火的一个算法,是一种基于Bagging的集成学习方法,能够很好地处理分类和回归的问 ...
2022-12-23方差分析是数据分析中常用的一种统计分析方法,接下来让我们简单了解一下方差分析的基本思想和原理吧。 方差分析(Analysis ...
2022-12-23来源:关于数据分析与可视化 关于streamlit-aggrid 数据排序 表格样式的调整 数据 ...
2022-08-03作者:麦叔 定义 「把上面晦涩的概念汇成一句话就是:」 ❝ 回调函数就是一个被作为参 ...
2022-08-03现今,高学历人群日益增多,物以稀为贵的高学历光环淡去。无论本科生还是研究生,甚至博士生,求职竞争力都大不如前,就业压力越来越大。
2022-06-01某家企业10个人面试,有9个本科生……如何脱颖而出,除得体的举止和良好的沟通力外,证书成重要筹码,这也是很多人考证的关键所在。
2022-04-14