在SAS中同时使用DLM和DSD

时间:2016-09-12 17:52:30

标签: sas

我是SAS的新手并且正在学习它。 我已经读过,我们可以将DSD和DLM选项用于infile语句。

但是当我使用具有多个分隔符的数据执行以下操作时会出现错误。

代码:

data test;
infile cards dlm='@' dsd;
input pid visit $ dose;
cards;
101,vis1"0.05
102,vis2,0.1

错误:

NOTE: Invalid data for pid in line 254 1-8.
RULE:      ----+----1----+----2----+----3----+----4----+----5----+----6----+----7----+----8---
255        102,vis2,10mg
NOTE: Invalid data errors for file CARDS occurred outside the printed range.
NOTE: Increase available buffer lines with the INFILE n= option.
pid=. vist=05mg drug=102,vis2 _ERROR_=1 _N_=1
NOTE: SAS went to a new line when INPUT statement reached past the end of a line.
NOTE: The data set WORK.MH1 has 1 observations and 3 variables.
NOTE: DATA statement used (Total process time):
      real time           0.00 seconds
      cpu time            0.00 seconds

256  ;

你能帮助我理解这一点来建立我的知识吗?

1 个答案:

答案 0 :(得分:1)

这里的问题是你的DLM是' @' (意思是你说字段分隔符是@字符)但是你的数据显示','作为分隔符(逗号)。

因此,您的错误是SAS正在尝试将所有hta(" 102,vis2,10mg")读入一个数字字段(pid)。您需要更改为dlm=','或拥有不同的数据。