如何在sas宏中将日期转换为字符串
这是一个更大查询的一部分,用于创建一个包含一个月内观察结果的表,并使用该月作为表名。 我希望表名是一个合理的日期,而不是一个数字 为什么此%sysfunc(putc())函数不创建字符串如何在sas宏中将日期转换为字符串,sas,Sas,这是一个更大查询的一部分,用于创建一个包含一个月内观察结果的表,并使用该月作为表名。 我希望表名是一个合理的日期,而不是一个数字 为什么此%sysfunc(putc())函数不创建字符串 %macro transLiteralDate2Char(dateval=); %put numerical = &dateval.; %put sasdatavalue = %sysfunc(putc(&dateval,MONYY5.)); %mend; %transLiteralDa
%macro transLiteralDate2Char(dateval=);
%put numerical = &dateval.;
%put sasdatavalue = %sysfunc(putc(&dateval,MONYY5.));
%mend;
%transLiteralDate2Char(dateval=%sysfunc(mdy(3,1,2016)));
还可以使用%SYSFUNC()中的第二个参数
还可以使用%SYSFUNC()中的第二个参数
SAS中的
put
命令始终返回字符串。%sysfunc(putc())
和%sysfunc(putn())
之间的区别在于函数的第二个参数是什么类型的格式-putc
理解字符格式,而putn
理解数字格式。在本例中,由于日期格式是数字格式,因此需要使用%sysfunc(putn())
打印字符串。像这样:
%macro transLiteralDate2Char(dateval=);
%put sasdatavalue = %sysfunc(putn(&dateval,MONYY5.));
%mend;
%transLiteralDate2Char(dateval=%sysfunc(mdy(3,1,2016)));
查看示例了解更多信息。SAS中的
put
命令始终返回字符串。%sysfunc(putc())
和%sysfunc(putn())
之间的区别在于函数的第二个参数是什么类型的格式-putc
理解字符格式,而putn
理解数字格式。在本例中,由于日期格式是数字格式,因此需要使用%sysfunc(putn())
打印字符串。像这样:
%macro transLiteralDate2Char(dateval=);
%put sasdatavalue = %sysfunc(putn(&dateval,MONYY5.));
%mend;
%transLiteralDate2Char(dateval=%sysfunc(mdy(3,1,2016)));
查看示例了解更多信息。尝试使用putn而不是putcTry putn而不是putc