zoukankan      html  css  js  c++  java
  • 如何使用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逻辑库中*/

  • 相关阅读:
    博客搬到blog.csgrandeur.com
    CSGrandeur的WebGL学习——WebGL教程
    hihoCoder 1160 攻城略地
    HDU 5212 Code
    Ubuntu 14.04 MySQL同步
    Ubuntu 用vsftpd 配置FTP服务器
    Ubuntu14.04 Server amd64 配置 Apache+MySQL+Django
    LeetCode OJ 题解
    MFC+Android模拟器 实现 自动玩“天天爱消除”
    湖南2013第九届省赛解题报告(长期拖延更新中。。。)
  • 原文地址:https://www.cnblogs.com/SSSR/p/3936813.html
Copyright © 2011-2022 走看看