在SAS中导入txt文件

时间:2016-10-25 15:26:25

标签: import sas

我有一个带有评论的文本文件,我需要在SAS中导入。 文本文件看起来像这样

# DATA1
#
# -- 
#     
ID  nbmiss  x1  x2  x3  x4 
1   1           45  38  47 
2   0       37  45  39  51 
3   3                   58 
4   4               
5   0       68  45  73  76 
6   2               52  48

我在SAS中的输出必须如下所示

Obs x1 x2 x3 x4 
1    . 45 38 47 
2   37 45 39 51 
3    .  .  . 58 
4    .  .  .  . 
5   68 45 73 76 
6    .  . 52 48 

这就是我所做的。它给了我正在寻找的东西,但它很长。我认为有一种更简单的方法。

proc import datafile= 'Z:\bloc1data\data\data1.txt'
            out=class
            dbms=dlm
            replace;
       datarow=6;
     delimiter='09'x;
run;
proc print data = work.class label;
var VAR3 VAR4 VAR5 VAR6;
label VAR3='x1' VAR4='x2' VAR5='x3' VAR6='x4';
run;

我的问题是如何以简化的方式获得相同的输出?

感谢您的时间。

1 个答案:

答案 0 :(得分:0)

这是进行导入的部分:

proc import datafile= 'Z:\bloc1data\data\data1.txt'
            out=class
            dbms=dlm
            replace;
       datarow=6;
     delimiter='09'x;
run;

这对我来说似乎很短暂。四行实际代码行,大约一百个字符......数据步骤中的等效代码基本相同。

data want;
  infile 'z:\bloc1data\data\data1.txt' dlm='09'x dsd firstobs=6;
  input id nbmiss x1 x2 x3 x4;
run;

遗憾的是,该文件无法自动确定名称(否则您可以这样做)。 DBMS = DLM没有namerow选项来告诉它从哪里选择名称,因此您需要预处理该文件以删除无关的行来执行此操作。欢迎您作为一个单独的问题询问如何这样做,但它并不简单"更简单"比上面(虽然它可能是#34;更好")。