SAS: имя набора данных Удалить дату и заменить текущей датой - PullRequest
0 голосов
/ 09 октября 2018

У меня сейчас есть макрос, который перемещает мой набор данных из одной ветви в другую.В каждом движении дата обновляется.Однако у меня возникают проблемы с автономным удалением старой даты перед вводом новой даты, какой-либо совет?

Код:

%Macro Merge_Branch(Branch = , Filename = , Library = );

    %Let Timestamp = %sysfunc(putn(%sysfunc(date()),yymmddn8.));

    %if &Branch. = Latest_Commit %then %do;

        Data LC._&Timestamp._&Filename.;
        set &Library..&Filename.;
        run;

    %end;

    %else %if &Branch. = Staging %then %do;

        %Let Filename = _20180909_Financial_Input;
        %Let Filename_temp = %scan(&Filename.,2,'_');
                %Let Date_String = %scan(&Filename.,1,'_');
                /* this is the section where I get stuck the dash is a subtraction i.e. I want to remove the date and just have the string*/
        %Let Filename_Stg = &Filename_temp - &Date_String;

        Data Stg._&Timestamp._&Filename_Stg.;
        set LC.&Filename.;
        run;

    %end;

%mend;

Input data can be made like this

data LC._20180909_Financial_Input;
var var1;
datalines;
1
1
1
1
;
run;

%Macro Merge_Branch(Branch = Staging , Filename = Financial_Input, Library = LC );

/*Note, in this macro the library is not important because it will always move from LC to STG*/

1 Ответ

0 голосов
/ 09 октября 2018

Ваше новое имя файла соответствует этому.

Data Stg._20181009_Financial - 20180909;

Это не SASNAME.

...