我有一个带有评论的文本文件,我需要在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;
我的问题是如何以简化的方式获得相同的输出?
感谢您的时间。
答案 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;更好")。