1. 一个宏变量存放的值保持不变直到被修改(全局变量
  2. 引用时,变量名前加上"&"
  3. 宏变量在引用时放在双引号之间会被解读(单引号不会被解读)

用户定义的宏变量,有三种方式:

  1. %let 宏变量名=宏变量值(宏变量值最大可存储65535个字符)
  2. call symput(宏变量名,值);(这个方法只允许在data步中)
  3. proc sql

宏变量的引用

显示宏变量及其值

  • _GLOBAL_ :输出用户自定义的宏变量当中的全局宏变量信息;

  • _LOCAL_ :输出用户自定义的宏变量当中的局部宏变量信息;(一般用在宏内部,因为只有在宏内部才有局部的概念)

  • _READONLY_ :输出用户自定义的宏变量中只读的宏变量信息,包括全局和局部的;

  • _WRITABLE_:输出用户自定义的宏变量中可写的宏变量信息,包括全局和局部的;

宏变量与后续文本的分隔

当宏变量跟后续文本紧密同时使用时,需要界定宏变量的结束位置

间接引用宏变量

“&宏变量名”是直接引用

如果引用的宏变量名是通过宏产生的,则需要间接引用,此时需要用:&&

DATA STEP

如果要在DATA STEP执行阶段创建Macro Variable,就要使用执行阶段生效的语句。在DATA STEP中可通过CALL SYMPUT来完成

CALL SYMPUT( macro-variable, value );
  • macro-varialbe为Macro Variable的名字,可以为引号引起来的字符串,也可以为DATA STEP中的字符变量;

  • value为Macro Variable的取值,可以为引号引起来的字符串;也可以为DATA STEP中的变量(如果是数值变量,SAS会进行一次自动转换,将其转换为字符串后赋给Macro Variable)

此外,还有另外一个CALL SYMPUTX也是用来在DATA STEP中创建Macro Variable。它与CALL SYMPUT的用法一模一样,只有一个区别:

CALL SYMPUTX在给Macro Variable赋值的时候会移除Leading blanks和Trailing blanks

注意:%put语句在输出时会移除输出内容的Leading blanks和Trailing blanks

PROC SQL

SQL相比DATA步可以很快速的完成一些聚合运算。这些运算后的结果如果想要输出到Macro Variable中,就需要用INTO子句来完成。其语法格式如下:

INTO :macro-variable-specification-1 <, :macro-variable-specification-2 ...>

特别注意,INTO子句中需要在每个创建的Macro Variable前加“:”

除了上面这种赋单值外,还可以赋多个值给某个Macro Variable,并且以指定的分隔符进行区分。例如:

%SYMDEL STATEMENT

当某个Macro Variable不再使用的时候,可以通过%symdel语句来删除

SAS学习笔记10 宏变量的更多相关文章

  1. SAS学习笔记46 宏变量的可使用范围

    全局宏变量 在宏程序内部,除了使用%GLOBAL语句创建.在某些情况下,还可以直接使用DATA步中的CALL SYMPUT创建. 在一个宏程序中,在包含CALL SYMPUT的DATA步程序之前,如果 ...

  2. SAS学习笔记41 宏变量存储及间接引用

    Macro Variables存储在“Symbol Table”中.它是由Macro Processor在SAS启动时自动创建并维护的.SAS提供了一张视图来供我们查看Symbol Table中的内容 ...

  3. SAS学习笔记44 宏函数

    类SAS函数的宏函数 该部分函数共5个,其无论是名字.语法.功能都与SAS函数类似,只是在函数名前多了一个“%”.这5个宏函数分别是: %INDEX %LENGTH %SCAN %SUBSTR %UP ...

  4. SAS学习笔记43 宏语句

    流程控制 %GOTO语句与%label语句是结合起来使用的.首先通过%label语句定义一个位置,使用%GOTO语句可直接将程序的执行位置跳到该label标记位置,达到控制程序执行顺序的目的.可实现与 ...

  5. SAS学习笔记37 宏程序中parmbuff选项

    该选项用于指定宏可以接受可变参数列表,而且参数值保存在SYSPBUFF宏变量中.parmbuff的参数价值,其实就是每次执行宏程序时,可以指定不同数量的参数值,这些宏参数被保存在&syspbu ...

  6. SAS学习笔记42 宏程序

    Autocall Macro是由SAS提供的一些实现特定功能的Macro Program,可以在代码中直接使用 其中以Q开头的相比正常的多了隐藏特殊字符的功能(称之为Macro Quoting): K ...

  7. SAS学习笔记之《SAS编程与数据挖掘商业案例》(3)变量操作、观测值操作、SAS数据集管理

    SAS学习笔记之<SAS编程与数据挖掘商业案例>(3)变量操作.观测值操作.SAS数据集管理 1. SAS变量操作的常用语句 ASSIGNMENT 创建或修改变量 SUM 累加变量或表达式 ...

  8. SAS学习笔记之《SAS编程与数据挖掘商业案例》(5)SAS宏语言、SQL过程

    SAS学习笔记之<SAS编程与数据挖掘商业案例>(5)SAS宏语言.SQL过程 1. 一个SAS程序可能包含一个或几个语言成分: DATA步或PROC步 全程语句 SAS组件语言(SCL) ...

  9. thinkphp学习笔记10—看不懂的路由规则

    原文:thinkphp学习笔记10-看不懂的路由规则 路由这部分貌似在实际工作中没有怎么设计过,只是在用默认的设置,在手册里面看到部分,艰涩难懂. 1.路由定义 要使用路由功能需要支持PATH_INF ...

随机推荐

  1. ICEM-三棱锥的一种画法(2D转3D)

    原视频下载地址:https://yunpan.cn/cqwC3eZHn5AvJ  访问密码 9456

  2. cannot load from mysql.proc. the table is probably corrupted 解决办法

    执行以下命令:mysql_upgrade -u root -p 密码 mysql5.5及5.5以上的版本开始,mysql数据库中proc表中的comment字段的列属性已经由char(64)改为tex ...

  3. 20175313 张黎仙《Java综合讲座》第十三周课堂测试总结

    目录 一.JAVA中两大类型 二.基本类型与类类型的相互转化 三.int与Integer之间的区别 四.String.StringBuffer.StringBuilder三者之间的区别 五.Array ...

  4. python @classmethod

    写在前面 写博客的时候,我发现拖延症很严重,本来昨天要开始写的,结果东看看,西翻翻,啥也没落实下来.时间过去了,口袋里的收获却寥寥无几.讨厌这样的自己.我要戒掉这个不好的毛病. 拖延症的底层原因之一是 ...

  5. 在基于acpi的linux系统上如何检查当前系统是否支持深度睡眠?

    答: 执行以下命令: # dmesg|grep -i acpi |grep -i supports (S3表示支持深度睡眠) ACPI: (supports S0 S1 S3 S4 S5)

  6. angular自定义组件

    https://cli.angular.io/ 打开终端创建header组件: ng g component components/header import { Component, OnInit ...

  7. R-CNN论文学习

    Rich feature hierarchies for accurate object detection and semantic segmentation Tech report (v5) pr ...

  8. MySQL数据库备份之xtrabackup工具使用

    一.Xtrabackup备份介绍及原理 二.Xtrabackup的安装 1.在centos7上基于yum源安装percona-xtrabackup软件 [root@node7 ~]# yum -y i ...

  9. OneNote2016代码高亮插件的安装与使用

    OneNote2016代码高亮插件的安装与使用 使用效果 我觉得CSDN和博客园上面的许多讲解都不是很清晰,最后还是我自己弄好的.这里分享一下: 第一步要确认自己OneNote的版本是32位的还是64 ...

  10. 性能优化-Bitmap内存管理及优化

    Bitmap作为重要Android应用之一,在很多时候如果应用不当,很容易造成内存溢出,那么这篇文章的目的就在于探讨Bitmap的有效运用及其优化 缓存介绍 当多次发送请求的时候,请求同一内容,为了使 ...