楼主: Michael1941
4259 7

求助宏参数的设置 [推广有奖]

  • 0关注
  • 1粉丝

硕士生

57%

还不是VIP/贵宾

-

威望
0
论坛币
1087 个
通用积分
2.9700
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
960 点
帖子
73
精华
0
在线时间
222 小时
注册时间
2009-2-28
最后登录
2023-4-19

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
%macro bl(var);
proc sql noprint;
select name into :keeplist separated by ' '
from sashelp.vcolumn
where libname='WORK' and memname='A' and name like '&var';
quit;
%mend bl;

%bl(a%_1);


为什么调用这段宏后,提示:
WARNING: 没有解析宏 _1 的调用

二维码

扫码加我 拉你入群

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

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

关键词:proc sql separate SASHELP VCOLUMN warning where

沙发
mingfeng07 学生认证  发表于 2014-12-12 15:29:46 |只看作者 |坛友微信交流群
这个%是触发宏引用的字符,%_1指对宏_1进行解析,为了避免这个情况,你可以用%bl(%nrstr(a%_1));另外在解析宏变量用双引号,如name like “&var”。

使用道具

藤椅
yztqwedsa 发表于 2014-12-12 16:19:36 |只看作者 |坛友微信交流群
%是用来调用宏程序的,你这样写sas就会把_1看成宏程序,改为%bl(%str(a%_1))就行

使用道具

板凳
Michael1941 发表于 2014-12-13 11:07:07 |只看作者 |坛友微信交流群
%macro bl(var);
proc sql ;
        select name into :keeplist separated by ' '
        from sashelp.vcolumn
        where libname='WORK' and memname='A' and name like "&var";
quit;
%mend bl;
%bl(%nrstr(a%_1));
proc means n nmiss mean;
var &keeplist;
title "均数";
run;

谢谢上面两位,之前都问题就能解决,可是在下面都proc means中调用宏程序里面生产都keeplist变量又出错,提示:Error:变量KEEPLIST没有找到,这个是什么原因呢,忘多指导,纯新手,谢谢

使用道具

报纸
Michael1941 发表于 2014-12-13 11:23:03 |只看作者 |坛友微信交流群
273  %bl(%nrstr(a%_1));
NOTE: “PROCEDURE SQL”所用时间(总处理时间):
      实际时间         0.00 秒
      CPU 时间         0.00 秒



274  proc means n nmiss mean ;
275  var &keeplist;
         -
         22
          --------
          202
WARNING: 没有解析符号引用 KEEPLIST。
ERROR: 变量 KEEPLIST 没有找到。
ERROR 22-322: 语法错误,期望下列之一: 名称, ;, /, _ALL_, _CHARACTER_, _CHAR_, _NUMERIC_.
ERROR 202-322: 该选项或参数不可识别,将被忽略。
276  title "均数";
277  run;

NOTE: SAS 系统由于错误而停止了该步的处理。
NOTE: “PROCEDURE MEANS”所用时间(总处理时间):
      实际时间         0.01 秒
      CPU 时间         0.01 秒

使用道具

地板
Michael1941 发表于 2014-12-13 11:51:00 |只看作者 |坛友微信交流群
mingfeng07 发表于 2014-12-12 15:29
这个%是触发宏引用的字符,%_1指对宏_1进行解析,为了避免这个情况,你可以用%bl(%nrstr(a%_1));另外在解析 ...
谢谢你都答复,能在帮忙看看嘛?

使用道具

7
sas_user 发表于 2014-12-13 13:37:58 |只看作者 |坛友微信交流群
keeplist 是一个local 宏变量,宏结束就消失了。
把proc means 放到宏里面就行了
已有 1 人评分论坛币 收起 理由
admin_kefu + 30 根据规定进行奖励

总评分: 论坛币 + 30   查看全部评分

使用道具

8
Michael1941 发表于 2014-12-13 13:54:43 |只看作者 |坛友微信交流群
sas_user 发表于 2014-12-13 13:37
keeplist 是一个local 宏变量,宏结束就消失了。
把proc means 放到宏里面就行了
感谢,已经搞定了

使用道具

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-27 11:25