京公网安备 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
在数据可视化领域,单一图表往往难以承载多维度信息 —— 力导向图擅长展现节点间的关联结构与空间分布,却无法直观呈现 “流量 ...
2025-10-27这个问题问到了 Tableau 中两个核心行级函数的经典组合,理解它能帮你快速实现 “相对位置占比” 的分析需求。“index ()/size ( ...
2025-10-27对 CDA(Certified Data Analyst)数据分析师而言,“假设检验” 绝非 “套用统计公式的机械操作”,而是 “将模糊的业务猜想转 ...
2025-10-27在数字化运营中,“凭感觉做决策” 早已成为过去式 —— 运营指标作为业务增长的 “晴雨表” 与 “导航仪”,直接决定了运营动作 ...
2025-10-24在卷积神经网络(CNN)的训练中,“卷积层(Conv)后是否添加归一化(如 BN、LN)和激活函数(如 ReLU、GELU)” 是每个开发者都 ...
2025-10-24在数据决策链条中,“统计分析” 是挖掘数据规律的核心,“可视化” 是呈现规律的桥梁 ——CDA(Certified Data Analyst)数据分 ...
2025-10-24在 “神经网络与卡尔曼滤波融合” 的理论基础上,Python 凭借其丰富的科学计算库(NumPy、FilterPy)、深度学习框架(PyTorch、T ...
2025-10-23在工业控制、自动驾驶、机器人导航、气象预测等领域,“状态估计” 是核心任务 —— 即从含噪声的观测数据中,精准推断系统的真 ...
2025-10-23在数据分析全流程中,“数据清洗” 恰似烹饪前的食材处理:若食材(数据)腐烂变质、混杂异物(脏数据),即便拥有精湛的烹饪技 ...
2025-10-23在人工智能领域,“大模型” 已成为近年来的热点标签:从参数超 1750 亿的 GPT-3,到万亿级参数的 PaLM,再到多模态大模型 GPT-4 ...
2025-10-22在 MySQL 数据库的日常运维与开发中,“更新数据是否会影响读数据” 是一个高频疑问。这个问题的答案并非简单的 “是” 或 “否 ...
2025-10-22在企业数据分析中,“数据孤岛” 是制约分析深度的核心瓶颈 —— 用户数据散落在注册系统、APP 日志、客服记录中,订单数据分散 ...
2025-10-22在神经网络设计中,“隐藏层个数” 是决定模型能力的关键参数 —— 太少会导致 “欠拟合”(模型无法捕捉复杂数据规律,如用单隐 ...
2025-10-21在特征工程流程中,“单变量筛选” 是承上启下的关键步骤 —— 它通过分析单个特征与目标变量的关联强度,剔除无意义、冗余的特 ...
2025-10-21在数据分析全流程中,“数据读取” 常被误解为 “简单的文件打开”—— 双击 Excel、执行基础 SQL 查询即可完成。但对 CDA(Cert ...
2025-10-21在实际业务数据分析中,我们遇到的大多数数据并非理想的正态分布 —— 电商平台的用户消费金额(少数用户单次消费上万元,多数集 ...
2025-10-20在数字化交互中,用户的每一次操作 —— 从电商平台的 “浏览商品→加入购物车→查看评价→放弃下单”,到内容 APP 的 “点击短 ...
2025-10-20在数据分析的全流程中,“数据采集” 是最基础也最关键的环节 —— 如同烹饪前需备好新鲜食材,若采集的数据不完整、不准确或不 ...
2025-10-20在数据成为新时代“石油”的今天,几乎每个职场人都在焦虑: “为什么别人能用数据驱动决策、升职加薪,而我面对Excel表格却无从 ...
2025-10-18数据清洗是 “数据价值挖掘的前置关卡”—— 其核心目标是 “去除噪声、修正错误、规范格式”,但前提是不破坏数据的真实业务含 ...
2025-10-17