京公网安备 11010802034615号
经营许可证编号:京B2-20210330
在一个 SAS 程序中,你可以根据需要引用宏变量任意次, 在你改变它之前它的值一直保 持 不变。下面的程序就引用了 DSN 两次。 DATA temp; SET &dsn; IF age>=20;PROC PRINT; TITLE "Subset of Data Set &dsn"; RUN; 每次&dsn 一出现,宏处理器就用 Newdata 代替它,SAS 实际执行的语句是∶ DATA TEMP; SET NEWDATA; IF AGE>=20; PROC PRINT; TITLE "Subset of Data Set Newdata"; RUN; 你也可以创建一个包含 SAS 语句的宏变量,如: %LET plot=%str( 这种情况下,宏变量的值都作为函数%STR 的实参, 于 是分 PROC PLOT; PLOT income*age; 可 RUN; 以赋空值,如: ) %LET dsn=Nextdata; %LET plot=; 第 1 个语句对 DSN 重新赋值 Nextdata,第 2 个语句对 PLOT 赋空值。 宏变量也可以嵌套 引用: %LET dsn=Olddata; %LET yvar=Income; %LET xvar=Age; %LET plot=%str( PROC PLOT; PLOT &yvar*&xvar; RUN; ) (程序的第 1 部分) SAS 实际执行的是如下的语句: DATA temp; SET &dsn; IF age>=20; &plot PROC PRINT; TITLE "Subset of Data Set &dsn"; RUN; (程序的第 2 部分) 号成为宏变量值的一部分,而不会被当做%LET 语句的结束。 要改变宏变量的值,只需用%LET 语句重定义, 宏变量也DATA TEMP; SET OLDDATA; IF AGE>=20; PROC PLOT; PLOT YVAR*XVAR; RUN; PORC PRINT; TITLE "Subset of Data Set Olddata"; RUN; 2. 宏 宏就是存贮的一个文本,最简单的宏工作起来很像一个宏变量,但是复杂的宏可以做许 多 宏变量无法完成的事。下面是一个最简单的宏定义。 %MACRO dsn; Newdata %MEND dsn; 宏定义总是由%MACRO 语句开始, 而且必须包含一个宏名。宏名遵从一般的 SAS 命名 规则, 这里的宏名叫 DSN。Newdata 是宏的内容, %MEND 作为宏定义的结束语句;这里 的 %MEND 语句为 了清晰还重复了宏名。要调用一个宏,只需放一个百分号(%)在宏名的前面,如: TITLE "Display of Data Set %dsn"; 宏处理器执行宏展开,用宏内容去代替%dsn,TITLE 语句成为: TITLE "Display of Data Set Newdata"; 同样,标题必须用双引号括起来。 一个 SAS 程序可以包含多个宏,一个宏也可以被多次调用,要改变一个象 DSN 这样简单 的宏 的内容,只需重新定义宏,对简单的文本代换,用宏变量比定义一个宏效率要高,但是当任 务比
较复杂的时侯,宏救宏变量要优越得多了。 下面的程序创建一个包含整段 SAS 程序的宏。 %MACRO plot; PROC PLOT; 以
后调用宏如下: PLOT income*age; RUN; %MEND plot; SAS 实际执行的语句是:
DATA temp; DATA TEMP; SET olddata; SET OLDDATA; IF age>=20; IF AGE>=20; %plot PROC PLOT; PROC PRINT; PLOT INCOME*AGE; RUN; RUN; PROC PRINT; RUN; 假设在 PROC PLOT 中的绘图变量可以改变,你就可以用宏变量引用去替换 PLOT 语句中 的变 量名,然后在调用宏之前用%LET 语句给宏变量赋值。 %MACRO plot; SAS 实际执行的是如下的语句: PROC PLOT; DATA TEMP; PLOT &yvar*&xvar; SET OLDDATA; RUN; IF AGE>=20; %MEND plot; PROC PLOT; DATA temp; PLOT INCOME*AGE; SET olddata; RUN; IF age>=20; PROC PLOT; %LET yvar=income; PLOT INCOME*YRS_EDUC; %LET xvar=age; RUN; %plot PROC PRINT; %LET xvar=yrs_educ; RUN; %plot PROC RRINT; RUN; 宏变量和宏结合起来使用,为灵活设计提供了极大的方便。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在数据分析、机器学习的实操场景中,聚类分析与主成分分析(PCA)是两种高频使用的统计与数据处理方法。二者常被用于数据预处理 ...
2026-02-24在聚类分析的实操场景中,K-Means算法因其简单高效、易落地的特点,成为处理无监督分类问题的首选工具——无论是用户画像分层、 ...
2026-02-24数字化浪潮下,数据已成为企业核心竞争力,“用数据说话、用数据决策”成为企业发展的核心逻辑。CDA(Certified Data Analyst) ...
2026-02-24CDA一级知识点汇总手册 第五章 业务数据的特征、处理与透视分析考点52:业务数据分析基础考点53:输入和资源需求考点54:业务数 ...
2026-02-23CDA一级知识点汇总手册 第四章 战略与业务数据分析考点43:战略数据分析基础考点44:表格结构数据的使用考点45:输入数据和资源 ...
2026-02-22CDA一级知识点汇总手册 第三章 商业数据分析框架考点27:商业数据分析体系的核心逻辑——BSC五视角框架考点28:战略视角考点29: ...
2026-02-20CDA一级知识点汇总手册 第二章 数据分析方法考点7:基础范式的核心逻辑(本体论与流程化)考点8:分类分析(本体论核心应用)考 ...
2026-02-18第一章:数据分析思维考点1:UVCA时代的特点考点2:数据分析背后的逻辑思维方法论考点3:流程化企业的数据分析需求考点4:企业数 ...
2026-02-16在数据分析、业务决策、科学研究等领域,统计模型是连接原始数据与业务价值的核心工具——它通过对数据的规律提炼、变量关联分析 ...
2026-02-14在SQL查询实操中,SELECT * 与 SELECT 字段1, 字段2,...(指定个别字段)是最常用的两种查询方式。很多开发者在日常开发中,为了 ...
2026-02-14对CDA(Certified Data Analyst)数据分析师而言,数据分析的核心不是孤立解读单个指标数值,而是构建一套科学、完整、贴合业务 ...
2026-02-14在Power BI实操中,函数是实现数据清洗、建模计算、可视化呈现的核心工具——无论是简单的数据筛选、异常值处理,还是复杂的度量 ...
2026-02-13在互联网运营、产品迭代、用户增长等工作中,“留存率”是衡量产品核心价值、用户粘性的核心指标——而次日留存率,作为留存率体 ...
2026-02-13对CDA(Certified Data Analyst)数据分析师而言,指标是贯穿工作全流程的核心载体,更是连接原始数据与业务洞察的关键桥梁。CDA ...
2026-02-13在机器学习建模实操中,“特征选择”是提升模型性能、简化模型复杂度、解读数据逻辑的核心步骤——而随机森林(Random Forest) ...
2026-02-12在MySQL数据查询实操中,按日期分组统计是高频需求——比如统计每日用户登录量、每日订单量、每日销售额,需要按日期分组展示, ...
2026-02-12对CDA(Certified Data Analyst)数据分析师而言,描述性统计是贯穿实操全流程的核心基础,更是从“原始数据”到“初步洞察”的 ...
2026-02-12备考CDA的小伙伴,专属宠粉福利来啦! 不用拼运气抽奖,不用复杂操作,只要转发CDA真题海报到朋友圈集赞,就能免费抱走实用好礼 ...
2026-02-11在数据科学、机器学习实操中,Anaconda是必备工具——它集成了Python解释器、conda包管理器,能快速搭建独立的虚拟环境,便捷安 ...
2026-02-11在Tableau数据可视化实操中,多表连接是高频操作——无论是将“产品表”与“销量表”连接分析产品销量,还是将“用户表”与“消 ...
2026-02-11