如何在SAS中计算出我的宏变量的数据类型

时间:2015-02-12 00:51:21

标签: sas sas-macro

如何在日志

中打印出宏变量的数据类型
%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()的东西

3 个答案:

答案 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);