24SAS处理流程与指针控制PPT课件.ppt

上传人:rrsccc 文档编号:10914135 上传时间:2021-06-12 格式:PPT 页数:20 大小:313.50KB
返回 下载 相关 举报
24SAS处理流程与指针控制PPT课件.ppt_第1页
第1页 / 共20页
24SAS处理流程与指针控制PPT课件.ppt_第2页
第2页 / 共20页
24SAS处理流程与指针控制PPT课件.ppt_第3页
第3页 / 共20页
24SAS处理流程与指针控制PPT课件.ppt_第4页
第4页 / 共20页
24SAS处理流程与指针控制PPT课件.ppt_第5页
第5页 / 共20页
点击查看更多>>
资源描述

《24SAS处理流程与指针控制PPT课件.ppt》由会员分享,可在线阅读,更多相关《24SAS处理流程与指针控制PPT课件.ppt(20页珍藏版)》请在三一文库上搜索。

1、第24章 SAS处理流程与指针控制,清华大学经管学院 朱世武 Z Resdat样本数据: SAS论坛: ,SAS处理流程,数据步定义,通过数据步可以实现的功能如下。 创建SAS数据集(SAS数据文件或SAS数据视窗); 读取外部数据文件创建SAS数据集; 通过对现有SAS数据集取子集、合并、修改和更新创建新的SAS数据集; 分析、操作或展示数据; 创建新变量; 产生报告、或将文件存储到硬盘或磁带上; 提取信息; 文件管理。,数据步处理流程,指针控制,当SAS从输入数据中读取数据,并将其读入到输入缓冲区时,用一个指针标记所读数据的位置。INPUT语句提供了三种方式来控制指针运动。,列行指针控制,

2、列指针控制指定变量从哪一列开始读入数据。 行指针控制可以实现如下控制: 将指针移动至下一次记录行; 在INPUT语句中定义每个观测所要读入的记录行数量,或在INFILE语句中使用N=选项设定每个观测所需读入的记录数量。,例24.2 列行指针控制。 data one; input 2 Name $ +1 age ; cards; sara 15 kitty 23 paul 24 ; run; 例中:2表示第一个变量Name从每个观测记录的第二列开始读取数据,在读完Name之后,+1表示此时指针向右相对移动一列读取age的数值。通过列表输入方式的INPUT语句,每读入一个数值之后,指针自动停留在数

3、据后的第二列上(如本例第一个数据行,读完sara后,指针已经指到sara后第二列上),所以此时指针只需相对向右一位,就能继续读入下一个变量。,使用行固定说明符,下列情况发生时使用行固定说明符使得指针停留在当前的输入记录行上。 一个数据记录行被多个INPUT语句读入(单尾缀)。 一个数据记录行包含多个观测所需要的值(双尾缀)。 一个数据记录行需要在下一个DATA步的重复过程中再次读入(双尾缀)。,单尾缀,一般来说,数据步中的每个INPUT语句都会将一条新的数据记录行读入输入缓冲区中,若用单尾缀控制,则在同一个重复过程中: 指针位置没有改变。 没有新的记录行被读入到输入缓冲区当中。 下一个INPU

4、T语句会继续读入同一条记录行。 SAS在使用单尾缀时,会在碰到以下情况时释放一条记录行: 一个空的INPUT语句: input; 一个不带单尾缀的input语句; 下一次重复过程开始。,例24.3 单尾缀的作用。 data one; input a b ; /*input语句1*/ input ; /*input语句2*/ input c d ; /*input语句3*/ cards; 1 2 3 4 1 2 3 4 ; run; 上述例子是一个标准组合顺序123 ,得到的结果是,如果是13组合,得到的结果,双尾缀,一般来说,若使用双尾缀,则数据步在进行下一次重复过程时,INPUT语句读入同一

5、条记录行。 在碰到下列情况时,SAS才会将一个记录行释放: 指针移动超过了输入记录的尾端; 空INPUT语句; 在DATA步下一次重复开始时,有一个单尾缀的INPUT语句input ;,例24.4 双尾缀的作用。 data one; input a b ; cards; 1 2 1 2 1 2 1 2 ; run; 例中,每个数据记录行可以完成两次重复过程,当指针移动超过了输入记录的尾端,指针才开始换行。,读完数据后的指针位置,分别用列表方式、列方式、格式化方式读入下一段数据,列表方式: input region $ jansales; 在读完REGION1之后,指针停留在第9列上。 -+-1

6、-+-2-+-3 REGION1 49670 ,格式化方式和列方式 列方式 input region $ 1-7 jansales 12-16; 格式化方式 input region $7. +4 jansales 5.; input region $7. 12 jansales 5.; I NPUT语句控制指针从前7列中读取数据赋给变量REGION,而后指针停留在第8列上。 -+-1-+-2-+-3 REGION1 49670 ,多个数据行构成一个观测,看下面的例子: data list2; infile datalines; input #4 name $ 1-10 #2 age 13-1

7、4 #3 team 16 ; datalines; li 12 1 wang 45 2 zhou 12 3 qian 3 4 zhang 23 5 ren 11 6 wu 1 7 qiu 98 8 ; proc print data=list2; quit;,input #4 name $ 1-10 #2 age 13-14 team 16 ; 对应输出窗口结果,指针超过行的结尾,在使用或+控制指针时,如果指针移动超过数据行的结尾,则自动转到下一次数据记录行的第一列,并将此信息输入到SAS日志中。 如下例: data one; input x +6 y; cards; 1 2 3 4 ; run;/*x=1 y=3*/,指针移到第一列之前,当列指针试图移到第一列之前的位置时,会被限制到第一列。 例24. 5 列指针移到第一列。 data one; input x (A-7) y; cards; 1 ; run;/*x=1 y=1*/ SAS在读完X的值之后,指针回到第一列。x和y有同样的值。,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 社会民生


经营许可证编号:宁ICP备18001539号-1