
當程序較長的時侯,就象上面 的程序一樣,總是使用%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; 假設你經常創(chuàng)建數據集 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 的優(yōu)點是你可以在調用 ANALYZE 之前分別重新定義和調試它們,在規(guī)模較大的宏中, 模 塊結構 是很重要的。 當你使用宏 ANALYZE 時,假設有時你需要執(zhí)行宏 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 去創(chuàng)建一個數據集, 因為宏處理器在把宏展開時并不 把小 寫字母轉換為大寫。于是%IF 語句作的比較是 YES=yes,當然為假,事與愿違。為了在調
用時不 管大小寫都正確,應該修改 ANALYZE 如下: %MACRO analyze(getdata,yvar,xvar); %IF %UPCASE(&getdata)=YES %THEN %create; %ELSE %plot; %MEND analyze; 其中宏函數%UPCASE 把小寫轉換為大寫。 假設你想創(chuàng)建一系列名字用于 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 可以是以前創(chuàng)建的宏變量,也可以是在當前的 DATA 步創(chuàng)建的。 這個宏變量以后可以直接引用, 也可以在 DATA 步用 SYMGET 函數引用。 從而實匣同的 數 據步中的值傳遞,如: x=SYMGET('number'); 數據步變量 X 的值就是數據集 TEMP 中的觀測個數。 也可以在 DATA 步用 SYMGET 函數引用。從而實匣同的數 據步中的值傳遞,如: x=SYMGET('number'); 數據步變量 X 的值就是數據集 TEMP 中的觀測個數。
數據分析咨詢請掃描二維碼
若不方便掃碼,搜微信號: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 無外鍵關聯表的 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