本帖最后由 花映碧水 于 2013-12-29 13:28 编辑 ( y- u! V5 n& d$ A$ ?
' O% W: ?- A, v8 {3 `- ]在此首先非常感谢会员“奚鑫”提供资源,为方便大家观看,特此将全文转载到数学中国方便大家直接查阅~
& B! g; I* v- H
6 }2 |" F7 V8 Q. p, N2 H& w4 C, N上次分享了如何用SAS读取空格分隔的文本文件,但是有时我们会遇到一个字段的内容中包含空格的情况,如果我们还用上次的方法就会发生读取错位。 在确认了数据内容中确实存在空格的情况下,我们需要和数据提供方进行商议,给出两种解决方案: 1.如果出现空格的情况比较少,并且去掉空格不影响数据准确性的前提下可以压缩掉空格; 2.如果出现空格的情况比较多,并且去掉后会影响数据准确性时,建议更换数据提供方式,使用其他分隔符分隔字段。 下面分享针对第二种方案如何导入以逗号分隔的文本文件。 需求如下: 在D:\下存放名为myfile.txt的文本文件,该数据是由四个字段组成,分别为IdNumberName Team Weight,其中Weight为数值变量,其余均为字符变量,各个字段以逗号分隔。需要将该文件导入到work库下的名为club的数据集中。 文件的内容如下: 1024,David,red,189 1049,Amelia,yellow,145 代码如下: data work.club; infile "D:\myfile.txt" dlm= ","; input IdNumber $ Name$ Team $ Weight; run; 代码分析: 与上次分享的代码唯一不同的地方是在infile语句后面多了一个dlm = ",",意思为导入的文件各个字段是以逗号作为分隔符。 补充说明: 可以用dlm选项指定其他分隔符,如:# | $ 等。
7 l' H) e' z% ]- K4 N# l" q( ?% J" E" `2 p3 {7 i9 @
|