登录
首页精彩阅读SAS在DATA步中调用PROC步
SAS在DATA步中调用PROC步
2017-06-13
收藏

SAS在DATA步中调用PROC步

给大家介绍一种方法,可以在DATA步中调用PROC过程,这样就可以在DATA步中对PROC产生的结果进行操作。

具体如何实现?

首先肯定不是直接在DATA步中写PROC,有些人可能会说用CALL EXECUTE,其实不然。CALL EXECUTE是在DATA步运行之后才调用。

在这里给大家介绍RUN_MACRO这个函数,通过该函数就可实现在DATA步中调用PROC,或者是另一个DATA步。

顾名思义,该函数就是用来调用macro的,但它有它的独特之处:不能在DATA步中使用该函数,只能在FCMP过程中使用(自定义函数中使用)。

因此要实现在DATA步中调用PROC,需要三个步骤:

1.定义一个MACRO,其内容就是一个PROC过程;

2.通过FMCP创建自定义函数,调用上面定义的MACRO;

3.在DATA步中调用自定义函数,即间接调用PROC过程;

下面用一个例子来说明:

创建宏(该宏是利用PROC SQL创建一个数据集,包含一个变量的非重复值

%macro distinct_values;

%let input_table = %sysfunc(dequote(&input_table));

%let column = %sysfunc(dequote(&column));

%let output_table = %sysfunc(dequote(&output_table));

proc sql;

create table &output_table as

select distinct &column

from &input_table;

%mend;

创建自定义函数(在自定义函数中调用上面定义的宏)

proc fcmp outlib=work.funcs.sql;

function get_distinct_values(input_table $, column $, output_table $);

rc = run_macro('distinct_values', input_table, column, output_table);

return (rc);

endsub;

run;

在DATA步中调用

options cmplib = work.funcs;

data _null_;

rc = get_distinct_values('sashelp.shoes', 'region', 'work.regions');

id=open('work.regions');

if id then nobs=attrn(id,'NOBS');

put nobs;

run;

通过这种方式就可在DATA中调用PROC,从而使用PROC生成的结果。在上面的例子中,最后的DATA步调用PROC生成了数据集WORK.REGIONS,

然后通过OPEN函数打开该数据集,获取到该数据集的观测数。当然你可以干其他的事情。

重点在于:RUN_MACRO调用宏后,会一直等待宏执行完毕后才返回。因此紧接着get_distinct_values自定义函数后就可以使用宏产生的数据。

如果使用CALL EXECUTE调用宏,是在DATA步执行完之后,才调用宏,实际上就是在DATA步之后增加了宏的调用。

注:虽然在第三步调用get_distinct_values之后就可以使用该数据,但不能使用SET WORK.REGIONS; 为什么呢?这是因为SET语句的运行机制决定的。

在程序编译阶段,如果有SET语句,就会将SET的数据集打开,但此时程序还未执行,数据集根本没有生成,因此就会报错,提示数据集不存在。

所以要使用OPEN函数,来对该数据集进行操作。


数据分析咨询请扫描二维码

客服在线
立即咨询