R2 | #30天专注橙长计划#~SAS~Day 12

��

2.17用导入过程(IMPORT procedure)读取PC文件

如果安装了SAS/ACCESS模块,导入过程(IMPORT procedure)可以导入一些PC文件类型。

它会浏览你的文件以决定变量类型,并默认使用数据的第一行来分配变量名。Wi ndows操作环境中可以导入excel、Lotus、dBase、和Access文件。Unix系统中可以导入dBase文件,并且从SAS9.1开始,Unix系统也可以导入excel和access文件。在windows环境中有一个不需要SAS/ACCESS模块的方法——Dynamic Data Exchange(DDE),将在2.18中讲解。

Microsoft ExcelLotus,和dBase文件下面是用导入过程(IMPORT procedure)读取PC文件的一般过程:

PROC IMPORT DATAFILE=’fi l ename’ OUT=data-set DBMS=i denti fi er REPLACE;

如果读取的文件是如下类型,就不用DBMS=OPTION。

R2 | #30天专注橙长计划#~SAS~Day 12_第1张图片

在读取excel时,有时需要指定要读取的是哪一个工作薄——sheet

SHEET=name-of-sheet;

默认情况下,导入过程(IMPORT procedure)会从工作薄的第一行中读取变量名。如果不需要,可以用如下代码使得SAS给变量赋名为F1,F2等。

GETNAMES=NO;

Mi crosoft Access Files读 取 这 种 文 件 需 要 用DATABASE=和DATATABLE=, 而 不 是

DATAFILE=option。

R2 | #30天专注橙长计划#~SAS~Day 12_第2张图片
R2 | #30天专注橙长计划#~SAS~Day 12_第3张图片

2.18用DDE读取PC文件

DDE,动态数据交换(Dynamic Data Exchange),读取PC文件的优点为:可以直接访问存于PC文件中的数据,不要求购买其他SAS产品;缺点为:只能用在windows环境下,只能在程序运行时(比如excel),SAS才能进行读取。

有几种方式可以用DDE访问数据:

复制数据到剪贴板

指定DDE三元组

从SAS中启动PC程序,然后读取数据。

复制数据到剪贴板  可以直接复制数据至剪贴板,然后再SAS程序的DDE FILENAME语句中是使用CLIPBOARD关键字。比如,excel中有如下的工作薄:

R2 | #30天专注橙长计划#~SAS~Day 12_第4张图片

FILENAME语句将指代的文件(BASEBALL)定义成DDE类型,并指定从剪贴板中去读取它(CLIPBOARD)。DDE默认空格为分隔符,如果变量值之间有空格,则要在INFILE语句中用NOTAB选项和DLM=’09’X选项,前者告诉SAS在变量值之间放置制表符, 后者告诉SAS将制表符定义为分隔符。如果数据中有缺失值,则要在INFILE中加入DSD和MISSOVER选项,前者将两个连续的分隔符视为缺失值,后者告诉SAS如果此行读完,不要进入下一行给未赋值的变量赋值。

指定DDE三元组这种方法可以不用复制数据,直接指定出文件的DDE三元组。DDE三元组的形式为:application| topic ! item

有一种方法可以在SAS中直接查看文件的DDE三元组,方法为:复制数据至剪贴板里,触发SAS会话,从解决方案(Solution)菜单中选择附件(accessories) ——DDE三元组。一个窗口会出现你复制文件的DDE三元组。比如,一个工作薄的DDE三元组为:

Excel |C:\MyFi l es \[BaseBal l .xl s]sheet1!R2C1:R5C7

读取这个文件的FILENAME语句为:

FILENAME basebal l DDE'Excel |C:\MyFi l es \[BaseBal l .xl s]sheet1!R2C1:R5C7';

从SAS中启动程序 这种方法可以不用在运行SAS之前启动数据程序。想要从SAS中启动程序,然后读取数据,则首先需要NOXWAIT和NOXSYNC系统选项,然后使用X语句,一个例子:

R2 | #30天专注橙长计划#~SAS~Day 12_第5张图片

NOXSYNC和NOXWAIT语句告诉SAS不要等待用户输入。X语句告诉windows执行或打开引号中路径的文件,注意这里路径设置了两个引号,如果路径中有空格,则要设置两个引号。使用这种方法,必须要在FILENAME语句中指定DDE三元组。

你可能感兴趣的:(R2 | #30天专注橙长计划#~SAS~Day 12)