树叶云SAS教程:SAS宏

SAS有一个强大的编程功能叫,它允许我们避免重复的代码段,并在需要时一次又一次地使用它们。 它还有助于在代码中创建动态变量,可以为同一代码的不同运行实例使用不同的值。 宏还可以声明为代码块,它将以类似于宏变量的方式被重复使用多次。 我们将在下面的例子中看到这两个。

宏变量

这些是保存由SAS程序一次又一次使用的值的变量。 它们在SAS程序开始时声明,并在程序体中稍后调用。 它们可以是全局或局部范围。

全局宏观变量

它们称为全局宏变量,因为它们可以由SAS环境中可用的任何SAS程序访问。 通常它们是由多个程序访问的系统分配的变量。 一般的例子是系统日期。

下面是一个名为SYSDATE的SAS变量的示例,它表示系统日期。 考虑一种方案,以便在生成报告的每天的SAS报告的标题中打印系统日期。 标题将显示当前日期和日期,而不为它们编码任何值。 我们使用SASHELP库中提供的名为CARS的内置SAS数据集。

proc print data = sashelp.cars;
where make = 'Audi' and type = 'Sports' ;
 TITLE "Sales as of &SYSDAY &SYSDATE";
run;

当运行上面的代码,我们得到以下输出。

局部宏变量

这些变量可以被SAS程序访问,在这些程序中它们被声明为程序的一部分。 它们通常用于向相同的SAS语句SL提供不同的变量,使得它们可以处理数据集的不同观察值。

句法

局部变量使用下面的语法声明。

% LET (Macro Variable Name) = Value;

这里的值字段可以采取程序所需的任何数字,文本或日期值。 宏变量名是任何有效的SAS变量。

这些变量由SAS语句使用,并在变量名的开头附加字符。 下面的程序得到我们所有的观察的’奥迪’和类型’体育’。 如果我们想要不同make的结果,我们需要更改变量make_name的值,而不改变程序的任何其他部分。 在带来程序的情况下,这个变量可以在任何SAS语句中被再次引用。

%LET make_name = 'Audi';
%LET type_name = 'Sports';
proc print data = sashelp.cars;
where make = &make_name and type = &type_name ;
 TITLE "Sales as of &SYSDAY &SYSDATE";
run;

当上面的代码运行时,我们得到与上一个程序相同的输出。 但是让我们将type_name改为’Wagon’,并运行相同的程序。 我们将得到以下结果。

宏程序

宏是一组SAS语句,由名称引用,并在程序中使用该名称在任何地方使用它。 它以%MACRO语句开始,以%MEND语句结束。

句法

局部变量使用下面的语法声明。

# Creating a Macro program.
%MACRO (Param1, Param2,….Paramn);

Macro Statements;

%MEND;

# Calling a Macro program.
%MacroName (Value1, Value2,…..Valuen);

以下程序在名为“show_result”的宏下对一组SAT staemnets进行解密; 此宏正由其他SAS语句调用。

%MACRO show_result(make_ , type_);
proc print data = sashelp.cars;
where make = "&make_" and type = "&type_" ;
TITLE "Sales as of &SYSDAY &SYSDATE";
run;
%MEND;

%show_result(BMW,SUV);

当运行上面的代码,我们得到以下输出。

常用的宏

SAS有许多MACRO语句,它们内置在SAS编程语言中。 它们被其他SAS程序使用,而没有明确声明它们。 常见的例子是 – 当满足一些条件时终止程序或捕获程序日志中变量的运行时值。 下面是一些例子。

宏%PUT

此宏语句将文本或宏变量信息写入SAS日志。 在下面的例子中,变量“today”的值被写入程序日志。

data _null_;
CALL SYMPUT ('today',
TRIM(PUT("&sysdate"d,worddate22.)));
run;
%put &today;

宏%RETURN

当某个条件的计算结果为真时,执行该宏将导致当前执行的宏正常终止。 在下面的示例中,当变量“val”的值变为10时,宏终止其它连接。

%macro check_condition(val);
   %if &val = 10 %then %return;

    data p;
       x=34.2;
    run;  

%mend check_condition;  

%check_condition(11)  ;

宏%END

此宏定义包含一个%DO%WHILE循环,根据需要以%END语句结束。 在下面的示例中,名为test的宏采用用户输入,并使用此输入值运行DO循环。 DO循环的结束通过%end语句实现,而宏的结束通过%mend语句实现。

%macro test(finish);
   %let i=1;
   %do %while (&i <&finish);
      %put the value of i is &i;
      %let i=%eval(&i+1);
   %end;
%mend test;
%test(5)

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/240849.html<

(0)
管理的头像管理
上一篇2025-04-24 01:44
下一篇 2025-04-24 01:45

相关推荐

  • 云服务器和云虚拟主机怎么选?云服务器和虚拟主机区别

    云服务器适合业务增长快、需弹性扩展的场景,而云虚拟主机适合预算有限、技术门槛低的小型静态网站或测试环境,二者核心区别在于资源独享性与运维复杂度,核心差异解析:从底层架构到使用体验很多人容易混淆这两者,觉得它们都是“买空间建站”,它们的底层逻辑完全不同,云服务器(ECS)就像是你租了一整栋别墅,水电网络独立,你想……

    2026-06-29
    0
  • 赣州智慧旅游招聘是真的吗?赣州旅游人才招聘信息

    中级岗位(3-5年经验)月薪范围通常在6000-10000元,这类岗位需要独立负责项目模块,如独立运营一个抖音账号,或维护一个景区小程序的功能迭代,具备成功案例的候选人议价能力较强,高级岗位(5年以上经验)月薪范围通常在10000-20000元,部分核心管理岗可达更高,这类人才需要具备战略规划能力,如制定整个景……

    2026-06-29
    0
  • 赣州智能物联网车位锁如何管理?智能车位锁管理系统多少钱

    赣州智能物联网车位锁管理的核心在于通过云端平台实现远程控锁、状态实时监控及自动计费,彻底解决传统车位“被占难管”与“找位难”的痛点,在赣州这样的城市,随着机动车保有量的持续增长,老旧小区、商业综合体以及私人固定车位的资源矛盾日益凸显,传统的机械地锁或简易遥控锁,不仅操作繁琐,更无法实现数据化管理,引入智能物联网……

    2026-06-29
    0
  • 赣州智能消防栓好用吗,智能消防栓多少钱一个

    赣州智能消防栓通过物联网技术实现实时监测与远程报警,能显著降低火灾响应时间并提升城市消防安全管理水平,是目前智慧城市建设中不可或缺的基础设施,赣州智能消防栓的核心价值与应用场景传统消防栓往往存在“看不见、摸不着、用不了”的痛点,在赣州这样地形复杂、老城区与新城区并存的区域,传统设施的管理难度极大,智能消防栓的出……

    2026-06-29
    0
  • 云服务器和物理机到底有啥区别?

    云服务器本质上是虚拟化资源池中的弹性实例,而传统物理服务器是独占的硬件实体,前者胜在弹性与运维便捷,后者强在物理隔离与性能稳定,具体选择取决于业务对成本、扩展性及安全合规的权衡,很多人初次接触服务器时,容易把“云服务器”和“传统物理服务器”混为一谈,觉得它们都是用来跑网站或存数据的盒子,这两者的底层逻辑完全不同……

    2026-06-29
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注