
在一個 SAS 程序中,你可以根據需要引用宏變量任意次, 在你改變它之前它的值一直保 持 不變。下面的程序就引用了 DSN 兩次。 DATA temp; SET &dsn; IF age>=20;PROC PRINT; TITLE "Subset of Data Set &dsn"; RUN; 每次&dsn 一出現,宏處理器就用 Newdata 代替它,SAS 實際執(zhí)行的語句是∶ DATA TEMP; SET NEWDATA; IF AGE>=20; PROC PRINT; TITLE "Subset of Data Set Newdata"; RUN; 你也可以創(chuàng)建一個包含 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 實際執(zhí)行的是如下的語句: 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 命名 規(guī)則, 這里的宏名叫 DSN。Newdata 是宏的內容, %MEND 作為宏定義的結束語句;這里 的 %MEND 語句為 了清晰還重復了宏名。要調用一個宏,只需放一個百分號(%)在宏名的前面,如: TITLE "Display of Data Set %dsn"; 宏處理器執(zhí)行宏展開,用宏內容去代替%dsn,TITLE 語句成為: TITLE "Display of Data Set Newdata"; 同樣,標題必須用雙引號括起來。 一個 SAS 程序可以包含多個宏,一個宏也可以被多次調用,要改變一個象 DSN 這樣簡單 的宏 的內容,只需重新定義宏,對簡單的文本代換,用宏變量比定義一個宏效率要高,但是當任 務比
較復雜的時侯,宏救宏變量要優(yōu)越得多了。 下面的程序創(chuàng)建一個包含整段 SAS 程序的宏。 %MACRO plot; PROC PLOT; 以
后調用宏如下: PLOT income*age; RUN; %MEND plot; SAS 實際執(zhí)行的語句是:
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 實際執(zhí)行的是如下的語句: 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被稱為“AI元年”,而AI,與數據密不可分。網易公司創(chuàng)始人丁磊在《AI思維:從數據中創(chuàng)造價值的煉金術》一書中指出:AI思維, ...
2025-07-17數據分析師的技能圖譜:從數據到價值的橋梁? 在數據驅動決策的時代,數據分析師如同 “數據翻譯官”,將冰冷的數字轉化為清晰的 ...
2025-07-17Pandas 寫入指定行數據:數據精細化管理的核心技能? 在數據處理的日常工作中,我們常常需要面對這樣的場景:在龐大的數據集里精 ...
2025-07-17解碼 CDA:數據時代的通行證? 在數字化浪潮席卷全球的今天,當企業(yè)決策者盯著屏幕上跳動的數據曲線尋找增長密碼,當科研人員在 ...
2025-07-17CDA 精益業(yè)務數據分析:數據驅動業(yè)務增長的實戰(zhàn)方法論 在企業(yè)數字化轉型的浪潮中,“數據分析” 已從 “加分項” 成為 “必修課 ...
2025-07-16MySQL 中 ADD KEY 與 ADD INDEX 詳解:用法、差異與優(yōu)化實踐 在 MySQL 數據庫表結構設計中,索引是提升查詢性能的核心手段。無論 ...
2025-07-16解析 MySQL Update 語句中 “query end” 狀態(tài):含義、成因與優(yōu)化指南? 在 MySQL 數據庫的日常運維與開發(fā)中,開發(fā)者和 DBA 常會 ...
2025-07-16如何考取數據分析師證書:以 CDA 為例? ? 在數字化浪潮席卷各行各業(yè)的當下,數據分析師已然成為企業(yè)挖掘數據價值、驅動決策的 ...
2025-07-15CDA 精益業(yè)務數據分析:驅動企業(yè)高效決策的核心引擎? 在數字經濟時代,企業(yè)面臨著前所未有的數據洪流,如何從海量數據中提取有 ...
2025-07-15MySQL 無外鍵關聯(lián)表的 JOIN 實戰(zhàn):數據整合的靈活之道? 在 MySQL 數據庫的日常操作中,我們經常會遇到需要整合多張表數據的場景 ...
2025-07-15Python Pandas:數據科學的瑞士軍刀? ? 在數據驅動的時代,面對海量、復雜的數據,如何高效地進行處理、分析和挖掘成為關鍵。 ...
2025-07-15用 SQL 生成逆向回滾 SQL:數據操作的 “后悔藥” 指南? 在數據庫操作中,誤刪數據、錯改字段或誤執(zhí)行批量更新等問題時有發(fā)生。 ...
2025-07-14t檢驗與Wilcoxon檢驗的選擇:何時用t.test,何時用wilcox.test? t 檢驗與 Wilcoxon 檢驗的選擇:何時用 t.test,何時用 wilcox. ...
2025-07-14AI 浪潮下的生存與進階: CDA數據分析師—開啟新時代職業(yè)生涯的鑰匙(深度研究報告、發(fā)展指導白皮書) 發(fā)布機構:CDA數據科 ...
2025-07-13LSTM 模型輸入長度選擇技巧:提升序列建模效能的關鍵? 在循環(huán)神經網絡(RNN)家族中,長短期記憶網絡(LSTM)憑借其解決長序列 ...
2025-07-11CDA 數據分析師報考條件詳解與準備指南? ? 在數據驅動決策的時代浪潮下,CDA 數據分析師認證愈發(fā)受到矚目,成為眾多有志投身數 ...
2025-07-11數據透視表中兩列相乘合計的實用指南? 在數據分析的日常工作中,數據透視表憑借其強大的數據匯總和分析功能,成為了 Excel 用戶 ...
2025-07-11尊敬的考生: 您好! 我們誠摯通知您,CDA Level I和 Level II考試大綱將于 2025年7月25日 實施重大更新。 此次更新旨在確保認 ...
2025-07-10BI 大數據分析師:連接數據與業(yè)務的價值轉化者? ? 在大數據與商業(yè)智能(Business Intelligence,簡稱 BI)深度融合的時代,BI ...
2025-07-10SQL 在預測分析中的應用:從數據查詢到趨勢預判? ? 在數據驅動決策的時代,預測分析作為挖掘數據潛在價值的核心手段,正被廣泛 ...
2025-07-10