楼主: sswangjy
3189 3

求助一个关于宏的问题 [推广有奖]

  • 5关注
  • 1粉丝

已卖:6份资源

硕士生

58%

还不是VIP/贵宾

-

威望
0
论坛币
2246 个
通用积分
137.8650
学术水平
3 点
热心指数
9 点
信用等级
4 点
经验
4051 点
帖子
75
精华
0
在线时间
281 小时
注册时间
2015-3-27
最后登录
2021-2-5

楼主
sswangjy 发表于 2016-3-18 21:50:18 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
新手自学sas,写了个计算现值的宏,运行的时候发现,参数代入数值是可以调用的,但是如果参数是变量名,就报错了,求助求助!
宏;
*计算现值;
%macro pv(r,n,c,p);
cpv=0;
%do i=1 %to &n;
cpv=cpv+&c/(1+&r)** &i;
%end;
tpv=cpv+&p/(1+&r)** &n;
output;
%mend pv;

调用1:
data test;
%pv(0.1,2,5,100);
run;


调用2:
data test;
r=0.1;
n=2;
c=5;
p=100;
%pv(r,n,c,p);
run;


如上所示,第一种调用是可以成功的,但是采用第二种方式调用则会报错,错误信息如下:

190  data test;
191  r=0.1;
192  n=2;
193  c=5;
194  p=100;
195  %pv(r,n,c,p);
ERROR: 在需要数值操作数的 %EVAL 函数或 %IF 条件中发现字符操作数。条件是: &n
ERROR: %TO 值(%DO I 循环中)无效。
ERROR: 宏 PV 将终止执行。
196  run;

NOTE: 由于出错,SAS 系统停止处理该步。
WARNING: 数据集 WORK.TEST 可能不完整。该步停止时,共有 0 个观测和 5 个变量。
WARNING: 数据集 WORK.TEST 由于该步已停止,而没有被替换。
NOTE: “DATA 语句”所用时间(总处理时间):
      实际时间          0.03 秒
      CPU 时间          0.03 秒


二维码

扫码加我 拉你入群

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

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

关键词:warning output Error outpu Macro 信息

回帖推荐

tonic_zlj 发表于3楼  查看完整内容

同意楼上。当成函数用的macro有一些特殊限制,比如编译语句的时候要跟data步没有调用关系。如果一定要在data步里面用,不如直接用 %macro pv; cpv=0; do i=1 to n; cpv=cpv+c/(1+r)** i; end; tpv=cpv+p/(1+r)** n; %mend pv; /*调用2:*/ data test; r=0.1; n=2; c=5; p=100; %pv; run;

孤单的我们 发表于2楼  查看完整内容

调用2 宏是先编译再执行的,编译期间检查语法 %pv(r,n,c,p)中%do i=1 %to &n;,而data步没有执行。 所以会报错 ERROR: 在需要数值操作数的 %EVAL 函数或 %IF 条件中发现字符操作数。条件是: &n ERROR: %TO 值(%DO I 循环中)无效。 ERROR: 宏 PV 将终止执行。
http://studynotes0fjz.blog.163.com/

沙发
孤单的我们 发表于 2016-3-19 11:24:09
调用2
  1. data test;
  2. r=0.1;
  3. n=2;
  4. c=5;
  5. p=100;
  6. %pv(r,2,c,p);
  7. run;
复制代码


宏是先编译再执行的,编译期间检查语法
%pv(r,n,c,p)中%do i=1 %to &n;,而data步没有执行。
所以会报错

ERROR: 在需要数值操作数的 %EVAL 函数或 %IF 条件中发现字符操作数。条件是: &n
ERROR: %TO 值(%DO I 循环中)无效。
ERROR: 宏 PV 将终止执行。
已有 2 人评分经验 学术水平 热心指数 收起 理由
eijuhz + 20 精彩帖子
sswangjy + 1 + 1 观点有启发

总评分: 经验 + 20  学术水平 + 1  热心指数 + 1   查看全部评分

藤椅
tonic_zlj 发表于 2016-3-20 08:35:14
同意楼上。当成函数用的macro有一些特殊限制,比如编译语句的时候要跟data步没有调用关系。如果一定要在data步里面用,不如直接用
%macro pv;
cpv=0;
do i=1 to n;
cpv=cpv+c/(1+r)** i;
end;
tpv=cpv+p/(1+r)** n;
%mend pv;

/*调用2:*/
data test;
r=0.1;
n=2;
c=5;
p=100;
%pv;
run;
已有 1 人评分学术水平 热心指数 收起 理由
sswangjy + 1 + 1 观点有启发

总评分: 学术水平 + 1  热心指数 + 1   查看全部评分

板凳
sswangjy 发表于 2016-3-21 00:05:37
灰常感谢,楼上两位结合起来我就彻底懂了~~

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-27 14:53