在我的SAS代码中,我希望根据我用提示符声明的日期值(LADE_DATUM)引用现有的文件夹。从现在开始,我定义了LADE_JAHR和LADE_MONAT:
%let LADE_JAHR = %sysfunc(year("&LADE_DATUM"D));
%let LADE_MONAT = %sysfunc(month("&LADE_DATUM"D));基于这两个变量,我想引用一些现有的文件夹(importpfad),它们看起来像: 2020-09,2020-10,2020-11,2020-12,等等。
代码如下:
data _null_;
if &lade_monat < 10 then a = '0'; else a = '';
call symput('a',a);
%let importpfad = /folderx/Input_Files/**&lade_jahr/&lade_jahr.-&a.&lade_monat**/;问题是,如果a= '‘,那么它引用的文件夹看起来像"2020-10“而不是"2020- 10”。
所以中间有一个我不想要的空格。
如果a介于1和9之间,则一切正常。
发布于 2021-01-05 22:29:11
只需告诉%SYSFUNC(),您希望使用Z格式而不是默认的best格式生成月份数字。
%let LADE_MONAT = %sysfunc(month("&LADE_DATUM"D),Z2.);
%let importpfad = /folderx/Input_Files/&lade_jahr/&lade_jahr.-&lade_monat/;https://stackoverflow.com/questions/65580601
复制相似问题