SAS 函数

SAS函数是编程语言的一个组件,可接受参数、执行计算或进行其他操作并返回值。返回值是字符型或数值型的结果,可用于赋值语句或 表达式中。SAS包含很多函数,也可以自定义函数。在BASE SAS软件 中,SAS函数可用于DATA步编程、WHERE表达式、宏语言语句、 PROC REPORT和结构化查询语言SQL(Structured Query Language)。

SAS函数的形式如下:

函数名(参数1  <,  ...参数n>)
函数名(OF 变量列表)
函数名(参数 | OF 变量列表 | OF数组名{*} <..., 参数 | OF 变量列表 | OF数组名{*} >)

其中:

  • ·函数名用于给出函数名称。
  • ·参数可以是变量名、常量或任何SAS表达式。多个参数间使用逗号(,)分隔。
  • ·变量列表可以是任何形式的变量列表。多个列表之间使用空格分 隔。例如sum(of x y z)、sum(of x1-x10)、sum(x,of x1-x5y1- y5)、sum(x,of x1-x5,of y1-y5)。最后两种表示方式具有同等效果。
  • ·数组名{*}指在当前DATA步中已经定义的数组。

数值函数

字符操作函数


数值与字符转换函数

1.PUT函数

PUT函数使用指定的格式返回值,可用于将数字值转换成字符值。 其基本形式如下:

PUT(源,  格式)

其中,源为要进行重新格式化的常量、变量或表达式,可以是字符型或数值型。格式为要应用在源上的SAS格式。PUT函数可用于将数字 根据格式转换为字符或将字符值转换为其他字符。默认情况下,如果源 是数值型,结果字符串会向右对齐,如果源是字符型,则结果字符串会 向左对齐。也可以在格式中添加对齐标识-L、-C、-R分别表示左对齐、 居中或右对齐,改变默认对齐方式。格式必须与源的类型一致。也就是说,如果源是字符,格式名必须以$符号开始;如果源是数字,格式则不能以$开始。PUT函数不影响数据集中的变量格式或属性。

子公司员工信息保存在saslib.employee2中,使用PUT函数对 Emp_ID的数值进行转换,并创建新的字符型变量New_Emp_ID,同 时,使用DROP语句将原始变量Emp_ID删除,之后再使用RENAME语 句将New_Emp_ID改名为Emp_ID。这样,所生成数据集中包含的变量 名就会保持不变。该过程很容易理解,这里不再给出数据示例进行讲 解。相关代码如下:

data  saslib.employee2;
set saslib.employee2;
New_Emp_ID=put(Emp_ID, best10.);
drop Emp_ID;
rename New_Emp_ID=Emp_ID;
run;

2.INPUT函数

INPUT函数返回当SAS使用指定输入格式转换SAS值之后的结果。 其基本形式如下:

INPUT(源,  输入格式)

其中,源为要应用输入格式的字符常量、字符变量或字符表达式。 格式为要应用在源上的SAS输入格式。

INPUT函数会将源的值使用指定的输入格式进行转换。INPUT函数 可用于将字符值转换为数字值或其他字符值。输入格式指定了结果是数 值型还是字符型。INPUT函数也不影响数据集中的变量输入格式或属性。

公司需要对员工入职日期进行排序,首先要将日期值(Date)转换 为数字。这里使用INPUT函数,并使用输入格式date9.将字符格式的日 期值(例如“01JAN2012”)转换为该日期对应的数字进行存储。代码如 下:

data  saslib.sales;
set saslib.sales;
Num_Date=input(Date, date9.);
drop Date;
rename Num_Date=Date;
run;
proc print data=saslib.sales noobs;
run;
proc contents data=saslib.sales;
run;

与日期时间相关的函数

SAS提供日期(date)、时间(time)和日期时间(datetime)函数从日期、时间和日期时间值中得到年份、月份、日、小时、分钟、秒等 信息,它们也可以将这些信息组成SAS的日期、时间和日期时间值。表3.13给出了SAS中常用的与日期、时间相关的函数。除此之外,SAS还 提供对日期的间隔进行操作的函数,详细情况请参考SAS帮助文档。

将公司员工入职日期中的年份、月份和日分别提取出来, 建立新的变量Year、Month和Day。

代码如下:

data  work.employee_ymd;
set saslib.employee;
Year = year(Entry_Date);
Month = month(Entry_Date);
Day = day(Entry_Date);
run;

SAS 函数的更多相关文章

  1. SAS学习经验总结分享:篇三—SAS函数

    SAS函数学习 文章为原创,禁止复制或转载,转载请标明出处, http://www.cnblogs.com/smallcrystal/p/4842346.html 1.函数输写格式: 1)一般书写格式 ...

  2. sas 基础(1)-关于数据格式的SAS函数

    (一)字符转换: 1)字符型转换成数值型 Numvar=INPUT(source,informat) 2)数值型转换成字符型 Chavar=PUT(source,format) (二)字符型变量的处理 ...

  3. SAS学习笔记44 宏函数

    类SAS函数的宏函数 该部分函数共5个,其无论是名字.语法.功能都与SAS函数类似,只是在函数名前多了一个“%”.这5个宏函数分别是: %INDEX %LENGTH %SCAN %SUBSTR %UP ...

  4. SAS 操作数据集的观测

    SAS  操作数据集的观测 1. SAS表达式 表达式是操作数和操作符的序列,该序列会形成一组可执行并产生 结果值的指令.其中,操作数可以是常量.变量或表达式:操作符是表 示比较.数学计算或逻辑运算的 ...

  5. SAS笔记

    SAS基础知识 SAS里面的PROC一览 The ACECLUS Procedure : 聚类的协方差矩阵近似估计(approximate covariance estimation for clus ...

  6. sas教程

    http://web5.pku.edu.cn/pucssr/SASbiancheng.pdf 本教程中的主题将向您介绍 SAS Enterprise Guide.您最好依次浏览这些主题. 概述 启动项 ...

  7. sas编程-日期相差计算函数 intnx

    sas编程-日期相差计算函数 intnx 示例代码: data _null_;    lastdate=intnx('year',today(),-100);    format lastdate  ...

  8. SAS中常见的数组函数

    SAS中常见的数组函数有: dim dimk hbound hboundk lbound lboundk 数组函数计萁数组的维数.上下界,有利于写出可移植的程序,数组函数包括:dim(x) 求数组x第 ...

  9. SAS常用函数

    SAS常用函数 一.数学函数  ABS(x) 求x的绝对值. MAX(x1,x2,…,xn) 求所有自变量中的最大一个. MIN(x1,x2,…,xn) 求所有自变量中的最小一个. MOD(x,y) ...

随机推荐

  1. Jsp页面输入中文,MYSQL数据库乱码???问题

    首先,先看一下自己mysql数据库的编码格式 其次,cmd模式下执行命令set names gbk 最后,更改my.ini文件文件参数为gbk 那为什么会产生乱码问题呢? 原因有以下几种: 一.项目编 ...

  2. VirtualBox安装Ubuntu16.04过程

    1. 软件版本 Windows: Win7/Win10 VirtualBox: VirtualBox-6.0.24-108355-Win Ubuntu: ubuntu-16.04-desktop-am ...

  3. SQL Server并发操作单个表时发生在page页面级的死锁

    最近遇到的死锁问题都发生在并发操作单张表上,比较有意思,就模拟了重现了一下.根据非聚集索引为条件,删除某一个表的数据,类似于这么一个语句,delete from table where noclust ...

  4. EF 数据迁移 常见错误

    1.错误 “LC.exe”已退出,代码为 -1 原因:解决方案出错,而非迁移的项目

  5. TS和C#的差异

    1. TS中let a : () => void; 假设有个class  B,  B里有个方法 c; 不能像C#委托一样, a = B.c;...........如果这样的话方法c里调用的thi ...

  6. Eclipse设置所有新创建文件默认格式为UTF-8

    一.为什么需要设置所有新创建文件默认格式为UTF-8 Eclipse编码默认是ISO-8859-1,不支持中文.而很多时候,我们的文件中含有中文,或者需要在创建文件时就需要是UTF-8编码格式的.在创 ...

  7. python 网络编程粘包解决方案2 + ftp上传 + socketserver

    一.struct 神奇的打包工具 struct 代码: import struct num = 156 #将int类型的数据打包成4个字节的数据 num_stru = struct.pack('i', ...

  8. webpack打包优化

    https://www.cnblogs.com/vvjiang/p/9327903.html

  9. python 基础 ----- 常用的方法

    one.将英文字符设置大小写 upper()  :将英文字符设置大写 lower()   :将英文字符设置小写 two.去掉字符串的首尾空格    不能去除字符串中间的空格偶 strip() : 去掉 ...

  10. 自动化测试框架对比(UIAutomator、Appium)

    在Android端,appium基于WebDriver协议,利用Bootstrap.jar,最后通过调⽤用UiAutomator的命令,实现App的自动化测试. UiAutomator测试框架是And ...