��
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 Excel,Lotus,和dBase文件下面是用导入过程(IMPORT procedure)读取PC文件的一般过程:
PROC IMPORT DATAFILE=’fi l ename’ OUT=data-set DBMS=i denti fi er REPLACE;
如果读取的文件是如下类型,就不用DBMS=OPTION。
在读取excel时,有时需要指定要读取的是哪一个工作薄——sheet
SHEET=name-of-sheet;
默认情况下,导入过程(IMPORT procedure)会从工作薄的第一行中读取变量名。如果不需要,可以用如下代码使得SAS给变量赋名为F1,F2等。
GETNAMES=NO;
Mi crosoft Access Files读 取 这 种 文 件 需 要 用DATABASE=和DATATABLE=, 而 不 是
DATAFILE=option。
2.18用DDE读取PC文件
DDE,动态数据交换(Dynamic Data Exchange),读取PC文件的优点为:可以直接访问存于PC文件中的数据,不要求购买其他SAS产品;缺点为:只能用在windows环境下,只能在程序运行时(比如excel),SAS才能进行读取。
有几种方式可以用DDE访问数据:
复制数据到剪贴板
指定DDE三元组
从SAS中启动PC程序,然后读取数据。
复制数据到剪贴板 可以直接复制数据至剪贴板,然后再SAS程序的DDE FILENAME语句中是使用CLIPBOARD关键字。比如,excel中有如下的工作薄:
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语句,一个例子:
NOXSYNC和NOXWAIT语句告诉SAS不要等待用户输入。X语句告诉windows执行或打开引号中路径的文件,注意这里路径设置了两个引号,如果路径中有空格,则要设置两个引号。使用这种方法,必须要在FILENAME语句中指定DDE三元组。