如何使用sas proc过程步产生的结果

如何使用sas proc过程步产生的结果,获得output窗口中的结果,将output窗口中的结果转换成数据集,直接读取output窗口中结果

我们在使用SAS的proc过程步时,所产生的结果默认输出到output窗口。SAS不提供对output窗口数据的直接读取,必须要转换成数据集,并且有时还会需要数据集的变量名(尤其是中文版中的数据集显示的是label)。本文利用ods trace和proc contents 实现对proc univariate过程步的信息读取。

本文使用sashelp中的class数据集做为原始数据集。

 

Ods简介

Proc 过程步简介

Proc contents简介

第一步,我们要首先获得proc过程步所生成的对象名称。

ods trace on/listing;

proc univariate data=sashelp.class;

var height;

run;

ods trace off;/*查看此过程步生成的对象名称*/

ods trace Arguments

Listing :writes the trace record to the Listing destination, so that each part of the trace record immediately precedes the output object that it describes.

 

第二步:将proc过程步产生的对象输出为数据集,使用ods output。

 

ods listing close;

ods output TestsForLocation=TestsForLocation;/*第一个TestsForLocation是生成的数据集名称,第二个TestsForLocation是proc过程步产生的对象名称。*/

proc univariate data=sashelp.class;

var height;

run;

ods listing;/*将生成的对象输出为数据集,这里存放在work逻辑库中*/

ods output

 

第三步:获得proc contents过程步产生的对象名称。

 

ods trace on/listing;

proc contents data=TestsForLocation out=a;/*可以生产数据集方便对变量名的统计*/

run;/*查看数据集中各列的属性*/

ods trace off;

在以后的分析中我们需要获得数据集中的变量名称,所以要将Variables对象导出为数据集。代码如下:ods listing close;

ods output Variables=Variables;

proc contents data=TestsForLocation out=a;/*可以生产数据集方便对变量名的统计*/

run;/*查看数据集中各列的属性*/

ods listing;/*将生成的对象输出为数据集,这里存放在work逻辑库中*/

转载于:https://www.cnblogs.com/SSSR/p/3936813.html

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值