立即打开
SAS学习笔记:SAS语言基础知识
1 赋值语句 在 SAS 中用赋值语句计算一个值并存放到变量中。
格式为 变量名=表达式:
2 输出语句
SAS 数据步的输出一般是数据集,用赋值语句计算的结果会自动写入数据集。 SAS 也提供了一个 PUT 语句,可以象其它语言程序的 PRINT , WRITE , printf 等语句一样立即显示输出结果。 PUT 语句在关键字后面列出要输出的各项,每一项可以是变量名或字符串,不能为数值常量或表达式,各项之间用空格分开。 PUT 语句的输出结果显示在 LOG 窗口。例如:
data ;
x = 1 ; y = sin ( x );
put 'sin function value of' x ' is ' y ;
run ;
结果 sin function value of 1 is 0 . 8414709848
PUT 语句的输出项还可以指定具体列位置
put x 10 - 20 . 6 ; X 数值显示在第 10 - 20 列,保留 6 位小数
put x 20 . 6 y 20 . 8 ; X 显示在 1 - 20 列, 6 位小数。 Y 显示在 21 - 40 列, 8 位小数
如果希望 PUT 语句的输出不产生换行,使下一个 PUT 的结果可以显示在同一行,只要在 PUT 语句结尾处加一个 @ 符,
如 put x @ ;
PUT 语句的输出结果缺省情况下被送到运行记录窗口。在 PUT 语句之前用 FILE 语句可以改变 PUT 语句的输出目的地。比如,在 PUT 语句之前用 file print ;
可以把 PUT 语句的输出转向到输出窗口。
在 FILE 语句中指定一个包含文件名的字符串可以把 PUT 语句的输出转向到此文件中。比如 file 'temp . out' ;把后续的 PUT 语句输出转向到当前工作目录下的文件 "tmp . out" 中,生成输出文件 tmp . out 。
3 分支结构
格式一: IF 条件 THEN 语句;
Else 语句;
有时我们在条件成立时需要进行的操作无法用一个语句完成,这时可以使用 SAS 提供的复合语句功能:只要把若干个语句用 "DO ; " 语句和 "END ; " 语句包围起来,就可以把它们看作是一个语句,就可以用在需要指定一个语句的地方。
if x>0 then do ;
put 'x 是正数 ' ;
x = 2*x ;
put x =;
end ;
格式二:
SAS 的 IF 结构允许嵌套,但 SAS 不提供 IF - ELSEIF - ELSE 的多分支结构。 SAS 的 SELECT 结构提供了更为灵活的多分支结构,可以实现比其它语言的 IF - ELSEIF - ELSE 结构更强的功能。 SELECT 结构有两种基本用法,第一种为:
SELECT (选择表达式);
WHEN (值列表)语句;
WHEN (值列表)语句;
OTHERWISE 语句:
END ;
另一种形式:
SELECT ;
WHEN (条件)语句;
WHEN (条件)语句;
OTHERWISE 语句:
END ;
4 循环结构
计数 DO 循环
DO 计数变量=起始值 TO 结束值 BY 步长:
循环体语句……:
END ;
在循环体中可以用 LEAVE 语句跳出循环,相当于 C 语言的 break 语句。
在循环体内用 CONTINUE 语句可以立即结束本轮循环并转入下一轮循环的判断与执行。
( 2 )当型循环
DO WHILE 循环继续条件:
循环体语句……:
END ;
( 3 )直到型
DO UNTIL 循环退出条件:
循环体语句……:
END ;
事实上, SAS 的循环语句比上面所述还要灵活得多它在 DO 语句中可以指定一个循环列表,比如
循环变量 i 取 5 , 7 , 1 1 , 14 循环体被执行,当 i 取 17 时 i 的平方为 289 故循环体不被执行,循环结束。注意 WHILE 条件只作用于用逗号隔开的最后一项。
5 数组
SAS 可以把一组同为数值型或同为字符型的变量合在一起,使用同一个名字称呼,用下标来区分。这与通常的程序设计语言中的数组略有区别,通常的程序设计语言中数组元素没有对应的变量名,而 SAS 数组每个元素都有自己的变量名。
一、数值型数组
定义:
ARRAY 数组名(维数说明)数组元素名列表(初始值表);
例如: array tests ( 3 ) math chinese english ( 0 , 0 , 0 );
初始值表可以省略,这时其初始值为相应数组元素的值(如果其数组元素还没有值则初值为缺失值)
数组元素名列表可以省略, array tests ( 3 )
也可以在说明维数时用 " 下标下界:下标上界 " 来说明一个其它的下标下界,如 ARRAY sales ( 95 : 97 ) yr95 - yr97 ;这时 sales ( 95 )为 yr95 , sales ( 96 )为 yr96 , sales ( 97 )为 yr97 。
一维数组的维数说明还可以是一个星号,比如:
array tests ( * ) math chinese english ( 0 , 0 , 0 );
二维数组定义,只要在维数说明中指定用逗号分开的两个下标界说明,例如: array table ( 2 , 2 ) x11 x12 x21 x22 ;注意,二维数组元素按行排列。
二、字符数
定义: ARRAY 数组名(维数说明) $ 元素长度说明 数组元素名列表(初始值表);
三、临时数组
SAS 也提供了与其它程序设计语言相同的数组,即数组元素只由数组名和序号决定,没有对应的变量名。这种数组叫做临时数组。
ARRAY 数组名(维数说明) _TEMPORARY_ (初始值表)
6 函数
表示形式:
SUM ( xl , x2 , x3 ) SUM ( OF xl x2 x3 )或 SUM ( OF xl - x3 )
1 数学函数
·ABS ( x )求 x 的绝对值。
·MAX ( xl , x2 , … , xn )求所有自变量中的最大一个。
·MIN ( xl , x2 , … , xn )求所有自变量中的最小一个。
·MOD ( x , y )求 x 除以 y 的余数。
·SQRT ( x )求 x 的平方根。
·ROUND ( x , eps )求 x 按照 eps 指定的精度四舍五入后的结果,比如 ROUND ( 5654 . 5654 , 0 . 01 )结果为 5654 . 57 , ROUND ( 5654 . 5654 , 10 )结果为 5650 。
·CEEL ( x )求大于等于 x 的最小整数。当 x 为整数时就是 x 本身,否则为 x 右边最近的整数。
·FLOOR ( x )求小于等于 x 的最大整数。当 x 为整数时就是 x 本身,否则为 x 左边最近的整数。
·INT ( x )求 x 扔掉小数部分后的结果。
·FUZZ ( x )当 x 与其四舍五入整数值相差小于 IE - 12 时取四舍五入。
·LOG ( x )求 x 的自然对数。
·LOG10 ( x )求 x 的常用对数。
·EXP ( x ) 指数函数
·SIN ( x ), COS ( x ), TAN ( x )求 x 的正弦、余弦、正切函数。
·ARSIN ( y ), ARCOS ( y ), ATAN ( y )
·SINH ( x ), COSH ( x ), TANH ( x )双曲正弦、余弦、正切。
此外还有符号函数 SIGN ,一阶导数函数 DIGAMMA ,二阶导数函数 TRIGAMMA 。
2 数组函数
·DIM ( x ) 求数组 x 第一维的元素的个数(注意当下界为 1 时元素个数与上界相同,否则元素个数不一定与上界相同)
·DIMk ( x ) 求数组 x 第 k 维的元素的个数。如 DIM2 ( x )计算二维数组 x 第二维长度。
·LBOUND ( x )求数组 x 第一维的下界。
·HBOUND ( x )求数组 x 第一维的上界。
·LBOUNDk ( x )求数组 x 第 k 维的下界。
·HBOUNDk ( x )求数组 x 第 k 维的上界。
3 字符函数
·TRIM ( s )返回去掉字符串 s 的尾随空格的结果。
UPCASE ( s )把字符串 s 中小写字母转换为大写字母后的结果。
·LOWCASE ( s )把字符串 s 中大写字母转换为小写字母后的结果。
·INDEX ( s , sl )查找 sl 在 s 中出现的位置。找不到时返回 0 。
·RANK ( s ) 字符 s 的 ASCII 码值。
·BYTE ( n )第 n 个 ASCII 码值的对应字符。
·REPEAT ( s , n )字符表达式 s 重复 n 次。
·SUBSTR ( s , p , n )从字符串 s 中的第 p 个字符开始抽取 n 个字符长的子串
·TRANWRD ( s , sl , s2 )从字符串 s 中把所有字符串 sl 替换成字符串 s2 后的结果。
4 日期和时间函数
·MDY ( m , d , yr )生成 yr 年 m 月 d 日的 SAS 日期值
·YEAR ( date )由 SAS 日期值 date 得到年
·MONTH ( date )由 SAS 日期值 date 得到月
·DAY ( date )由 SAS 日期值 date 得到日
·WEEKDAY ( date )由 SAS 日期值 date 得到星期几
·QTR ( date )由 SAS 日期值 date 得到季度值
·DHMS ( d , h , m , s ) 由 SAS 日期值 d 、小时 h 、分钟 m 、秒 s 生成 SAS 日期时间值
5 分布密度函数、分布函数
·分布函数值= CDF ( ' 分布 ' , x< ,参数表 > );
·密度值= PDF ( ' 分布 ' , x< ,参数表 > );
·概率值= PMF ( ' 分布 ' , x< ,参数表 > );
·对数密度值= LOGPDF ( ' 分布 ' , x< ,参数表 > );
·对数概率值= LOGPMF ( ' 分布 ' , x< ,参数表 > );
SAS数据统计分析培训
https://bbs.pinggu.org/thread-1818238-1-1.html
扫码加我 拉你入群
请注明:姓名-公司-职位
以便审核进群资格,未注明则拒绝
全部回复
扫码加我 拉你入群
请注明:姓名-公司-职位
以便审核进群资格,未注明则拒绝
相关推荐
栏目导航
热门文章
推荐文章
扫码加好友,拉您进群