SAS Макропеременная конкатенация ссылок - PullRequest
4 голосов
/ 30 марта 2011

Следующий код считывает в счете мобильного телефона из файла Excel и делает много очистки / отчетов.

%LET month = March;    
..........
PROC IMPORT OUT = PHONE.marchmin 
     DATAFILE = "D:\Data\cellphone\MarchBill.xls"    
     DBMS = EXCEL  REPLACE; 

     SHEET    = "Calls$"; 
     GETNAMES = YES;
     MIXED    = YES;
     SCANTEXT = YES;
     USEDATE  = YES;
     SCANTIME = YES;
RUN;

Чтобы упростить свою жизнь, я пытаюсь использовать макропеременную для обновления всех ссылок на март.Моя первоначальная идея, приведенная ниже, не работает.

%LET month = March;
.......
PROC IMPORT OUT = PHONE.&monthmin 
     DATAFILE = "D:\Data\cellphone\&monthBill.xls"    
     DBMS = EXCEL  REPLACE; 

     SHEET    = "Calls$"; 
     GETNAMES = YES;
     MIXED    = YES;
     SCANTEXT = YES;
     USEDATE  = YES;
     SCANTIME = YES;
RUN;

Она выдает следующую ошибку:

WARNING: Apparent symbolic reference MONTHMIN not resolved.
1551  PROC IMPORT OUT= PHONE.&monthmin
                             -
                             22
ERROR 22-322: Syntax error, expecting one of the following: ;, 
(, DATAFILE, DATATABLE, DBMS, FILE, OUT, REPLACE, TABLE.

Как мне получить эту ссылку на переменную month для корректного обновления?

1 Ответ

8 голосов
/ 30 марта 2011

Поставьте точку после & месяц.поэтому SAS знает, где находится конец макропеременной.например,

PROC IMPORT OUT = PHONE.&month.min
   DATAFILE = "D:\Data\cellphone\&month.Bill.xls"  
...