全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
1831 6
2017-09-02
悬赏 25 个论坛币 未解决
我有三个变量,x,y,z。我要做的事情是,生成x_new=x*2,y_new=y*2,z_new=z*2.我使用使用如下SAS发布的macro,未作任何改动,仅仅加了一行。然后在下面的data step调试,死活报错(ERROR 180-322: Statement is not valid or it is used out of proper order.)急急急!求帮忙!在线等。

***************
这是SAS发布的MACRO: Sample 26155: Loop through a nonsequential list of values with a macro DO loop

%macro loop(values);   
                                                                                                               
     /* Count the number of values in the string */                                                                                                                                   
     %let count=%sysfunc(countw(&values));

     /* Loop through the total number of values */                                                                                         
     %do i = 1 %to &count;                                                                                                              
      %let value=%qscan(&values,&i,%str(,));                                                                                            
      %put &value;   


&value._new=&value*2;

     %end;                                                                                                                              
                                                                                                                                       
%mend;                                                                                                                                 
                                                                                                                                       
这是我的调试代码,会报错:(ERROR 180-322: Statement is not valid or it is used out of proper order.)
data t;
x=1;
y=2;
z=3;
%loop(%str(x,y,z)) ;
run;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

全部回复
2017-9-2 12:42:37
这是我加的那行:&value._new=&value*2;
去掉这行,没有任何问题。帮忙看看这行到底是啥毛病啊!!!
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2017-9-2 19:17:13
&value._new=&value*2;
设&value=2,新变量是“2_new”,变量名不合法。
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2017-9-3 21:43:28
我试了一下,把%qscan 换成 %scan 就好了:

%macro loop(values);   
                                                                                                               
     /* Count the number of values in the string */                                                                                                                                   
     %let count=%sysfunc(countw(&values));

     /* Loop through the total number of values */                                                                                         
     %do i = 1 %to &count;                                                                                                              
      %let value=%scan(&values,&i,%str(,));                                                                                            
      %put &value;   


&value._new= &value.*2;

     %end;                                                                                                                              
                                                                                                                                       
%mend;      

data t;
x=1;
y=2;
z=3;
%loop(%str(x,y,z)) ;
run;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2017-9-4 23:20:42
你为什么要自动生成 x_new=x*2,y_new=y*2,z_new=z*2 这3条语句?

如果你准备用(x,y,z)去调用一个宏%loop(%str(x,y,z))来生成那3条语句,还不如就自己手写那3条语句。

我想你并没有把你的真实的最终的目的写出来。


二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2017-9-8 04:32:38
lyfyb99 is correct. My understanding is qscan masks the comma(,) in the string.
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

点击查看更多内容…
相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群