如何在日志
中打印出宏变量的数据类型%macro mymacro(dt2);
%LET c_mth = %SYSFUNC(intnx(month,&dt2.d,-1,e),date9.) ;
%put &c_mth;
%mend;
mymacro('01sep2014')
我使用%let或into分配了一堆宏变量: 我的问题是我试图在日期上做一堆布尔条件,但我怀疑我的一些变量是字符串,有些是日期 我已经在我的代码中输入了它们,但要进行三重检查,肯定有办法将某些内容返回到日志中
我想要类似于在R
中使用str()或mode()或is.numeric()的东西答案 0 :(得分:8)
H,
SAS宏语言很奇怪。 :)
正如Reeza所说,宏变量没有类型,它们都是文本。
但是,如果使用布尔逻辑(%IF语句),并且两个操作数都是整数,则宏语言将进行数字比较而不是字符比较。
因此,您可以使用INPUTN()函数将日期字符串转换为SAS日期(自01Jan1960以来的天数),然后进行比较。这是一个例子,从您的代码中跳出来:
%macro mymacro(dt1,dt2);
%local c_mth1 c_mth2 n_mth1 n_mth2;
%let c_mth1 = %sysfunc(intnx(month,&dt1.d,-1,e),date9.) ;
%let c_mth2 = %sysfunc(intnx(month,&dt2.d,-1,e),date9.) ;
%let n_mth1 = %sysfunc(inputn(&c_mth1,date9.)) ;
%let n_mth2 = %sysfunc(inputn(&c_mth2,date9.)) ;
%put &c_mth1 -- &n_mth1;
%put &c_mth2 -- &n_mth2;
%if &n_mth1<&n_mth2 %then %put &c_mth1 is before &c_mth2;
%else %put &c_mth1 is NOT before &c_mth2;
%mend;
从示例通话记录:
236 %mymacro('01feb1960','01mar1960')
31JAN1960 -- 30
29FEB1960 -- 59
31JAN1960 is before 29FEB1960
- :Q
答案 1 :(得分:5)
宏变量没有类型,它们都是文本。
您必须确保以对程序有意义的方式传递变量并生成有效的SAS代码。
%let date1=01Jan2014;
%let date2=31Jan2014;
data _null_;
x = "&date1"d > "&date2"d;
y = "&date2"d > "&date1"d;
z = "&date2"d-"&date1"d;
put 'x=' x;
put 'y=' y;
put 'z=' z;
run;
日志应显示: x = 0的 Y = 1 Z = 30
答案 2 :(得分:1)
如果您的宏变量解析为日期文字,您可以使用intck
与%eval
结合来比较它们,例如
%let mvar1 = '01jan2015'd;
%let mvar2 = '01feb2015'd;
/*Prints 1 if mvar2 > mvar1*/
%put %eval(%sysfunc(intck(day,&mvar1,&mvar2)) > 0);