SAS编程基础
- 格式:ppt
- 大小:302.00 KB
- 文档页数:14
一、SAS 基础SAS的全称为统计分析系统(Statistical Analysis System SAS),是当今国际上最著名的数据分析软件之一。
20世纪60年代末由美国北卡罗来纳州州立大学的几位教授开始研发,1975年创建美国SAS研究所。
之后,推出的SAS系统,经过30多年的不断发展与完善,目前已成为大型集成应用软件系统,是当前国际上较为流行、并且具有权威性的统计分析软件之一。
广泛应用于金融、医药卫生、通信和教育科研等领域,完成统计、图表分析、时间序列分析等工作。
SAS是一个庞大的系统,它由许多模块组成,每个SAS模块都是由很多可执行的文件组成,它们被称之为SAS过程(SAS PROCEDURE)。
我们在调用SAS过程解决具体问题时,通常需要用SAS语言编写一段程序,通过它建立起我们与SAS系统之间的联系,我们称之为SAS程序(SAS PROGRAM)。
应用SAS的关键就是要写出满足各种统计要求的SAS程序,编写程序的前提条件是我们要对SAS语言有较详细的了解,这一点对初学者来说有一定困难。
虽然,近年来随着图形界面、用户友好等程序思想的发展,在视窗版本的SAS中也逐渐提供了一些不需要编程就能进行数据管理、分析和绘图等功能,但是,SAS的编程方法在实际应用的过程中仍然是非常重要的。
许多学习SAS的人员通过自己的实践总结出一条经验,即“了解一些重要的基本概念,掌握一些重要语句的命令格式,使用和修改相关SAS书中或前人已写好的SAS程序,使其成为适合分析现有数据资料的新程序。
”这样可以使SAS的应用化繁为简、事半功倍。
一、启动SAS在Windows环境中,从开始菜单的程序文件夹中找到SAS 系统文件夹,从中启动SAS 系统。
或者将SAS.EXE 的快捷方式放到桌面上,然后双击SAS.EXE 启动。
二、SAS语言:SAS 系统强大的数据管理能力、计算能力、分析能力依赖于作为基础的SAS 语言。
SAS 语言是一个专用的数据管理与分析语言,它的数据管理功能类似于数据库语言(如FoxPro),但又添加了一般高级程序设计语言的许多成分,以及专用于数据管理、统计计算的函数。
很全的sas基础知识(一)5.1SAS表达式简介1.SAS常数表达式(1)数值常数如: 1.23、-5、0.5E-10。
(2)字符常数如: name1='TOME'、name2='MARY'、name3='JOHN'。
(3)日期(d)、时间(t)、日时(dt)常数如: d1='01JAN80'd、t1='9:25:19't、dt1='18JAN80:9:27:05'dt。
(4)16进制常数(略)2.SAS运算符(1)前缀算符与后缀算符前缀算符, 即正号或负号; 如: +Y; -25; -COS(30); +(X*Y); 后缀算符,即两个运算对象之间的运算符号, 如: 1+9; 4-2; 6<8。
(2)只含一个运算符的简单表达式(Ⅰ组)和含有多于一个运算符的复合表达式(Ⅱ组)Ⅰ组, 如: A+B; C-D; E*F; G/H; Ⅱ组, 如: 1-EXP(N/(N-1));100-LOG(N*(N+1));(3)操作运算的顺序求一个复合表达式的值时, 其操作运算的顺序和优先级遵从如下的规则(见表5.1): 表5.1SAS的运算符及其在运算顺序上的优先级━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━优先级组别运算符号等价表示运算符号含义之说明━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━第0 组()括号第 1 组**+-乘方, 正数, 负数^><<>NOT MIN MAX逻辑非, 最小, 最大第 2 组*/乘, 除第 3 组+-加, 减第 4 组‖或||字串连接第 5 组<<=LT LE小于, 小于等于=^=EQ NE等于, 不等于>=>GE GT大于等于, 大于IN等于一列元数中的某一个第 6 组&AND逻辑与第7 组|或|OR逻辑或━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━各组的计算顺序分别为: 第0组由内向外;其他各组均自左至右。
第三课 SAS编程–第一部分一.SAS 变量的定义/* 直接赋值 */data newvar;a1 = 100;a2 = 1.2e-5; /* 数值型变量的科学表达法 */b = 0100; /* 数值型变量前面的0不起作用 */c = ‘new’;d = “NEW” ; /*字符型变量输入时是什么,值就是什么*/f = “ NeW “;name1 = “Tom’s”;name2 = ‘Tom’’s’;date1 = ‘1jan2006’d; /* 直接定义日期 */ date2 = ‘01jan04’d;time1 = ‘9:25’t; /* 直接定义时间 */ time2 = ‘9:25:19’t;dtime = ‘18jan2003:9:27:05am’dt; /* 定义日期时间 */if begin=’01may04:9:30:00’dt then end=”31dec90:5:00:00”dt;run;proc print; run;/* 自定义变量 *//* 产生一个取值为 1 到 100 的变量 */data int;do i = 1 to 100; /* 此处 do … end 为循环语句, i 为循环指标,可取任何符号 */a = i;output;end;run;proc print; run;/* 简洁版 */data int;do a = 1 to 100;output;end;run;proc print; run;/* 通过各种运算定义变量 */SAS 算子用于比较: = (EQ) 等于,^= (NE) 不等于,~= (NE) 不等于, >(GT)大于,<(LT)小于, >=(GE)大于等于, <=(LE)小于等于算数运算:+ 加法,- 减法,* 乘法,/ 除法,** 幂次逻辑运算: & (AND) 和, | (OR) 或,~ (NOT) 非,^ (NOT) 非/* 旅游数据 */data travel;input country $ nights aircost landcost vendor $;cards;France 8 793 575 MajorSpain 10 805 510 HispaniaIndia 10 . 489 RoyalPeru 7 722 590 Mundial;run;data newair;set travel;length remarks $ 30; /* remark 的值会很长。
第一章:DATA 步阐述DA TA 步是SAS 的一个关键步,正确理解其执行过程将会学习起来更方便。
1)DATA 步是一个循环,数据是一行一行地执行(与SQL 过程不同,它是对整个数据集进行操作);2)DA TA 步在执行时,将数据放在PDV 中,在这里将数据整理成想要的格式3)有三种情况可将PDV 中的数据输出到数据集中,OUTPUT 语句,return 语句,data 步结尾(;或run;)Output 语句:此语句出现在data 步中间时,将PDV 中数据输出到SAS 数据后,继续执行直到data 步结尾。
Return 语句:将pdv 中数据输出到SAS 数据集后,返回到data 步开头,执行下一次循环。
data 步结尾(;或run;):缺省形式,也是必须语句,否则DATA 步不完整。
相当于一个放在data 步结尾处的return 语句。
注:当一个DATA 步中含有OUTPUT 语句时,当执行到语句output 时才输出PDV 中的数据,data 步结尾处的默认输出不起作用。
4)退出SAS 数据步:stop 语句和abort 语句;其作用是退出DATA 步,并丢掉PDV 中的数据。
data aa; input ss pay; if _error_ then delete ; pi=constant('PI');/*常数pi*/ format pi 15.13; e=CONSTANT('e');/*常数e*/ datalines ; 111 100 aaa 200 444 300 run ; proc print ;run ;结果相同(只读取了第一条观测),左边在LOG 窗口显示一个提示,右边则显示一个出错信息注:abort<return|abend>,退出SaS 系统(与正常退出相同,有相关提示)。
5)DA TA 步的短路: IF expression ;(子集IF 语句):若表达式是假,系统立即返回到DATA 步开头,继续执行下一条观测,且不处理当前观测。