全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
6409 1
2016-03-15

SAS学习笔记:SAS语言基础知识


1
赋值语句  在SAS中用赋值语句计算一个值并存放到变量中。
  格式为变量名=表达式:

2
输出语句

  SAS数据步的输出一般是数据集,用赋值语句计算的结果会自动写入数据集。SAS也提供了一个PUT语句,可以象其它语言程序的PRINTWRITEprintf等语句一样立即显示输出结果。PUT语句在关键字后面列出要输出的各项,每一项可以是变量名或字符串,不能为数值常量或表达式,各项之间用空格分开。PUT语句的输出结果显示在LOG窗口。例如:
    data
  x1 ysinx);
  put 'sin function value of' x ' is ' y
  run
  结果sin function value of 1 is 08414709848

  PUT语句的输出项还可以指定具体列位置
  put x 1020 6 X数值显示在第1020列,保留6位小数
  put x 206 y 208 X显示在120列,6位小数。Y显示在2140列,8位小数
  如果希望PUT语句的输出不产生换行,使下一个PUT的结果可以显示在同一行,只要在PUT语句结尾处加一个@符,
  如 put x @
  PUT语句的输出结果缺省情况下被送到运行记录窗口。在PUT语句之前用FILE语句可以改变PUT语句的输出目的地。比如,在PUT语句之前用file print
   可以把PUT语句的输出转向到输出窗口。
  在FILE语句中指定一个包含文件名的字符串可以把PUT语句的输出转向到此文件中。比如file 'tempout';把后续的PUT语句输出转向到当前工作目录下的文件"tmpout"中,生成输出文件tmpout

3 分支结构
  格式一: IF 条件 THEN 语句;
  Else 语句;
  有时我们在条件成立时需要进行的操作无法用一个语句完成,这时可以使用SAS提供的复合语句功能:只要把若干个语句用"DO"语句和"END"语句包围起来,就可以把它们看作是一个语句,就可以用在需要指定一个语句的地方。
  if x>0 then do
  put 'x是正数'
  x2*x
  put x=;
  end

  格式二:
  SASIF结构允许嵌套,但SAS不提供IFELSEIFELSE的多分支结构。SASSELECT结构提供了更为灵活的多分支结构,可以实现比其它语言的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语句中可以指定一个循环列表,比如
  循环变量i571 114循环体被执行,当i17i的平方为289故循环体不被执行,循环结束。注意WHILE条件只作用于用逗号隔开的最后一项。

  5 数组

  SAS可以把一组同为数值型或同为字符型的变量合在一起,使用同一个名字称呼,用下标来区分。这与通常的程序设计语言中的数组略有区别,通常的程序设计语言中数组元素没有对应的变量名,而SAS数组每个元素都有自己的变量名。

  一、数值型数组

  定义:
  ARRAY 数组名(维数说明)数组元素名列表(初始值表);
  例如:array tests3 math chinese english 0 0 0);
  初始值表可以省略,这时其初始值为相应数组元素的值(如果其数组元素还没有值则初值为缺失值)
  数组元素名列表可以省略,array tests3
  也可以在说明维数时用"下标下界:下标上界"来说明一个其它的下标下界,如 ARRAY sales 9597 yr95yr97;这时sales95)为yr95sales96)为yr96sales97)为yr97

  一维数组的维数说明还可以是一个星号,比如:
  array tests* math chinese english 0 0 0);
  二维数组定义,只要在维数说明中指定用逗号分开的两个下标界说明,例如:array table22 x11 x12 x21 x22;注意,二维数组元素按行排列。

  二、字符数
  定义:ARRAY 数组名(维数说明)$ 元素长度说明数组元素名列表(初始值表);

  三、临时数组
  SAS也提供了与其它程序设计语言相同的数组,即数组元素只由数组名和序号决定,没有对应的变量名。这种数组叫做临时数组。
  ARRAY数组名(维数说明) _TEMPORARY_ (初始值表)

  6 函数

  表示形式:
  SUMxlx2x3 SUMOF xl x2 x3)或SUMOF xlx3

  1 数学函数

  ·ABSx)求x的绝对值。
  ·MAXxlx2xn)求所有自变量中的最大一个。
  ·MINxlx2xn)求所有自变量中的最小一个。
  ·MODxy)求x除以y的余数。
  ·SQRTx)求x的平方根。
  ·ROUNDxeps)求x按照eps指定的精度四舍五入后的结果,比如ROUND 56545654001)结果为565457ROUND5654565410)结果为5650
  ·CEELx)求大于等于x的最小整数。当x为整数时就是x本身,否则为x右边最近的整数。
  ·FLOORx)求小于等于x的最大整数。当x为整数时就是x本身,否则为x左边最近的整数。
  ·INTx)求x扔掉小数部分后的结果。
  ·FUZZx)当x与其四舍五入整数值相差小于IE12时取四舍五入。
  ·LOGx)求x的自然对数。
  ·LOG10x)求x的常用对数。
  ·EXPx指数函数
  ·SINx),COSx),TANx)求x的正弦、余弦、正切函数。
  ·ARSINy),ARCOSy),ATANy
  ·SINHx),COSHx),TANHx)双曲正弦、余弦、正切。
  此外还有符号函数SIGN,一阶导数函数DIGAMMA,二阶导数函数TRIGAMMA

  2 数组函数

  ·DIMx求数组x第一维的元素的个数(注意当下界为1时元素个数与上界相同,否则元素个数不一定与上界相同)
  ·DIMkx求数组xk维的元素的个数。如DIM2x)计算二维数组x第二维长度。
  ·LBOUNDx)求数组x第一维的下界。
  ·HBOUNDx)求数组x第一维的上界。
  ·LBOUNDkx)求数组xk维的下界。
  ·HBOUNDkx)求数组xk维的上界。

  3 字符函数

  ·TRIMs)返回去掉字符串s的尾随空格的结果。
  UPCASEs)把字符串s中小写字母转换为大写字母后的结果。
  ·LOWCASEs)把字符串s中大写字母转换为小写字母后的结果。
  ·INDEXssl)查找sls中出现的位置。找不到时返回0
  ·RANKs字符sASCII码值。
  ·BYTEn)第nASCII码值的对应字符。
  ·REPEATsn)字符表达式s重复n次。
  ·SUBSTRspn)从字符串s中的第p个字符开始抽取n个字符长的子串
  ·TRANWRDssls2)从字符串s中把所有字符串sl替换成字符串s2后的结果。

  4 日期和时间函数
  ·MDYmdyr)生成yrmd日的SAS日期值
  ·YEARdate)由SAS日期值date得到年
  ·MONTHdate)由SAS日期值date得到月
  ·DAYdate)由SAS日期值date得到日
  ·WEEKDAYdate)由SAS日期值date得到星期几
  ·QTRdate)由SAS日期值date得到季度值
  ·DHMSdhmsSAS日期值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



二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

全部回复
2016-3-16 11:34:10
期待下级
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群