全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
25330 6
2013-01-09
SAS 中定义宏变量方法主要有以下三种:
   一、%LET定义
       这是最常用的方法。语法过程为:%let 宏变量名=值;调用宏变量:&宏变量名
       Tips:

       1、以逗号作为宏变量定义的结束。

       2、在定义时候不要加引号,系统会把引号当作宏变量的值之一。

       3、宏变量的作用域分为全局与局部。

           一种在程序(这里一般是指一个宏程序)外定义,则在整个SAS任何地方都可以被调用。

           另外一种则是在程序内部,则作用在该程序出现宏变量后面,在程序外则不可以被调用,否则

           会出错。(如果一个程序内部定义有宏变量变成全局变量,则需要使用%global)

       4、当宏变量一个表达式,使用:%str()
                    %let print=%str(proc print; run;);

       5、如果宏变量是数值计算表达式,则需要根据数值类型使用二个不同的宏变量:

                          %eval_r()   用于计算整数例如:%eval_r(1+2)

                         %sysevalf() 用于计算浮点数或者空值例如: %eval_r(1.0+2.3)
     二、data步中定义 call symput()
         这个方法只允许在data步中,这个一定需要注意
         语法过程:call symput("宏变量名",值);
               在DATA过程中,宏变量可以包括常值、变量值。或者函数赋予宏变量。
          三、 SQL过程中定义
              在使用SQL过程中定义宏变量,语法过程为:
             SELECT 宏值
              INTO :宏变量名
              SEPARATED BY ‘分隔符号’
            使用一个案例过程说明,以后我们再详细介绍其中的一个技巧:

data test;
input var @@;
datalines;
1 2 3 4 5
;
run;
proc sql noprint ;
select var into :macro_var
separated by ' '
from test;
quit;
二维码

扫码加我 拉你入群

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

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

全部回复
2013-1-9 15:38:22
学习,总结得很好,很用心啊
二维码

扫码加我 拉你入群

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

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

2013-10-10 00:15:59
学习了
二维码

扫码加我 拉你入群

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

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

2016-5-23 10:58:03
get!
二维码

扫码加我 拉你入群

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

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

2016-7-30 18:14:58
其实在宏中,如果使用%do 等宏函数,%do i= 1 %to 6;这样的语句时,便令i也会默认为宏变量的啦
二维码

扫码加我 拉你入群

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

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

2017-2-28 20:51:16
非常好,赞
二维码

扫码加我 拉你入群

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

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

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

说点什么

分享

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