在表达式中找不到必需的运算符:

Required Operator not found in Expression:

在下面的代码中,我在 then 语句中使用了宏变量,但是代码的任何变体似乎都失败了。

%MACRO LOOP_I;
    DATA JAV_WORK2;
        set WORK.JAV_WORK1;
        %do i = 1 %to 24 %by 1;
            %IF FF in ('CV', 'CV1', 'CV2', 'CVA', 'CVP', 'HAS') and S_TYPE in ('ETR_CARD', 'ETR_PCP', 'ETR_TRX') %THEN MONTH&i_SALES=trx&i;
            %ELSE %IF FF = 'HAS' and LENGTH(GEO_ID) = 6 and S_TYPE = ('ETR_DDD') %THEN MONTH&i_SALES= UNIT&i;
        %end;
    RUN;
%MEND LOOP_I;

%LOOP_I

当我尝试从 IF 语句中删除 % 时,我收到了 "ERROR 180-322: Statement is not valid or it is used out of proper order"。 TIA

您可以使用数组而不是宏循环来获得相同的结果。

data jav_work2;
    set jav_work1;

    array sales_month[24];
    array trx[24];
    array unit[24];

    if(FF  IN('CV', 'CV1', 'CV2', 'CVA', 'CVP', 'HAS') 
       AND S_TYPE in ('ETR_CARD', 'ETR_PCP', 'ETR_TRX')
    then do;

        do i = 1 to 24;
            sales_month[i] = trx[i];
        end;

            else if(FF = 'HAS' AND length(GEO_ID) = 6 AND S_TYPE = 'ETR_DDD') then do; 
               do i = 1 to 24
                  sales_month[i] = unit[i];
               end;
            end;
    end;
run;

如果您想使用相同的命名约定,您可以将其包含在一个宏中并修改 sales_month[24] 数组语句:

array sales_month[24] %do i = 1 %to 24; month&i._sales %end; ;