2016-11-17 246 views
0

我有一個宏,我正在傳遞6個表名和6列。但是,列和表的數量並不總是恆定的。SAS中宏的參數可變數量?

有沒有一種方法來有一個可變數量的參數?我用** kwargs熟悉python中的概念。

此外,有沒有一種方法來參數化proc sql語句只採取儘可能多的col和表輸入?或者在SAS中嘗試捕獲某種類型的變量以檢查在運行sql語句之前變量是否存在?

這是我想要參數化的宏。

%macro Generate_TP_tbl(new_tbl_name, trans_col, tbl_1, tbl_2, tbl_3, tbl_4, 
        tbl_5, tbl_6, col_1, col_2, col_3, col_4, col_5, col_6); 

proc sql; 

CREATE TABLE &new_tbl_name AS 

SELECT a1._NAME_, a1.&trans_col as &col_1, a2.&trans_col as &col_2, 
     a3.&trans_col as &col_3, a4.&trans_col as &col_4, a5.&trans_col as &col_5, 
     a6.&trans_col as &col_6 

FROM &tbl_1 as a1, &tbl_2 as a2, &tbl_3 as a3, &tbl_4 as a4, &tbl_5 as a5, 
    &tbl_6 as a6 

WHERE a1._NAME_ = a2._NAME_ = a3._NAME_ = a4._NAME_ = a5._NAME_ = a6._NAME_; 

run; 

%mend Generate_TP_table; 
+0

在列表中使用空格而不是逗號。那麼你只需要一個或兩個參數。 – Tom

回答

2

將它們作爲單個參數傳遞並讓它們稍後解析它們。

%macro (parameters = , table_list = tb1 tb2 tb3 ... tb6, col_list=col1 col2 ... col6, other_parms= ...); 

我建議使用具有參數數量的do循環來構建剩餘的代碼。這裏的文檔對如何提取列表中的每個元素的稍差例如:

http://support.sas.com/documentation/cdl/en/mcrolref/67912/HTML/default/viewer.htm#p1n2i0ewaj1zian1ria5579z1zjh.htm

的SQL是醜陋的...我不知道,如果一個數據的步驟會更容易些,因爲你正在合併上單變量?然後在許多方面,它就像上面的例子一樣真正成爲每個表的重命名。

3

一個更通用這樣的方式如下:

你可以調用%mymacro用你喜歡的任何參數和從&SYSPBUFF自動宏變量分析他們全力以赴。

這可能需要比Reeza的解決方案更多的工作,但我想我會張貼這個完整性,因爲它偶爾有用。

+0

我會說這是題目中提出的問題的正確答案,而Reeza's就是我在實際問題中提出的_this_問題的答案。 – Joe