SAS︱操作语句(if、do、select、retain、array)、宏语言、统计量、运算符号
每每以为攀得众山小,可、每每又切实来到起点,大牛们,缓缓脚步来俺笔记葩分享一下吧,please~
———————————————————————————
SAS中的一些常见的符号。运算符是一种符号
①比较算符
②算术算符
③逻辑算符
④其它算符
运算符号
比较算符 | 含义 |
#NAME? | 等于 |
^= 、 NE | 不等于 |
> 、 GT | 大于 |
< 、 LT | 小于 |
>= 、 GE | 大于等于 |
<= 、 LE | 小于等于 |
IN | 等于列表中的一个 |
算术算符
比较算符 | 含义 |
** | 乘方 |
* | 乘 |
/ | 除 |
+ | 加 |
- | 减 |
逻辑运算符
运算符 |
含义 |
^、NOT |
逻辑非 |
&、AND |
逻辑与 |
|、OR |
逻辑或 |
——————————————————————————————————————————————————————————
一、操作语句
1、if语句
- /*if语句*/
- if x then delete;
- if x=1 then y=1;
- else
- if x=2 then y=2;else
- y=3;
- /*抒写结构很有趣*/
- if status in (1,2) then newstat="single";
- else newstat="not single";
- /*表达式的写法*/
if代表判断,为真则执行then后面的内容。
其中newstat代表新的变量。
用途1:筛选变量
- data d1 d2;
- set sashelp.class;
- if _n_ le 10 then output d1;
- else output d2;
- run;
其中的le 代表小于等于10,
用途2:do强化if的效率
- If age>14 then hcm=30.5*height/12;
- if age>14 then do;hcm=30.5*height/12;end;
对比一下两个的关系,第一个是传统的if-then的组合,后面加上do-end,看上去多余,但是这样做之后,可以极大的增加运算效率。
2、select语句
- select语句
- select;
- when (a=1) x=a*10;
- when (a=2);
- when (a in (3.4.5)) x=a*100;
- otherwise;
- end;
类似if-then代表着如果when满足a=1,则x=a*10。
不过需要注意繁杂的的otherwiese 以及end作为必要后缀。
3、do语句
DO语句必须由一个END语句来结束。DO和END语句之间的这些语句称为一个DO组。
do语句有三类样式:简单DO语句;循环DO语句;do over语句
第一类的简单do,可见if中的用途2,强化了if的效率
第二类do,实质是循环,下面有一些常用写do语句的方式:
- do i=1 to n ;
- do i=n to 1 by –1;
- do i=1 to k-1, k+1 to n;
- do i=2, 3, 5, 7, 11, 13, 17;
- do i=0.1 to 0.9 by 0.1, 1 to 10 by 1, 20 to 100 by 10;
- do i='saturday', 'sunday';
- do i=‘A’ to ‘Z’;
一个例子:自然数求和、自然数平方和
- 自然数求和、自然数平方和
- data a2;
- t=0; s=0;
- do n=1 to 100;
- t=t + n;/*n累加*/
- s=s + n**2;/*n2累加*/
- output;
- end;
- run;
4、array语句
ARRAY语句用于定义数组。数组通常由一组变量构成。利用数组可以简化很多复杂的数据处理过程。 SAS系统引用数组等价于引用构成数组的那一组变量。
- data aa2;
- array c{4} (2,4,6,8);
- run;
5、retain语句——变量存储
利用retain语句可以很方便地实现观测值累加、累乘、缺失观测填充等复杂的数据处理。
(1)用于填充缺失值:
- data a12;set resdat.ymret;
- retain yret1;
- if yret^=. then yret1=yret;
- run;
在yret^=.的情况下为yret1赋值为yret,其它情况并没有为yret1赋值。由于retain语句的作用,yret1保留前面的值, 这样yret1不会有缺失值,从而起到填充的作用 。
(2)分组加上组序号:
- 分组,加组序号
- proc sort data=a12;by stock year;run;
- data a13;set a12;by stock year;
- retain num 0;
- if first.stock then num=num+1;
- run;
——————————————————————————————————————————————————————————
二、宏语言
SAS宏的一些特性:
1)可以降低重复性任务的工作量,便于重复调用。例如:可以将宏文件永久存储,每次只需要调用相应的宏就可以完成分析,而无需重新运行。
2)使程序模块化,同时便于修改宏参数,而无需重新运行,可以大幅提高运行效率。
1、sas宏变量——可复用的值
一个可以广泛复用,一直保存在缓存中的变量内容。 一种在程序(这里一般是指一个宏程序)外定义,则在整个SAS任何地方都可以被调用。另外一种则是在程序内部,则作用在该程序出现宏变量后面,在程序外则不可以被调用,否则会出错。(如果一个程序内部定义有宏变量变成全局变量,则需要使用%global)(这句话参考自: SAS 定义宏的三种用法)
(1)%let
- %let a=XXX;
- %put &a;
- %put here is &a;
- 显示:
- xxx
- here is xxx
通过%let定义宏变量,格式:%let 宏变量名=宏变量值;
定义了宏变量之间,需要print一下,就要使用%put,相当于print 一下。
还有这样的用法:
- %let var=you;
- data w1;
- X="here is &var";
- run;
直接用在的文本之中,作为嵌入式。
(2)%str()
另外宏变量的定义方式有:当宏变量一个表达式,使用:%str()
%let print=%str(proc print; run;);
(3)%eval()
如果宏变量是数值计算表达式,则需要根据数值类型使用二个不同的宏变量:
%eval_r() 用于计算整数例如:%eval_r(1+2)
%sysevalf() 用于计算浮点数或者空值例如: %eval_r(1.0+2.3)
还有一种就是%eval(),%eval把字符型值变成数值型。
2、宏程序——可以复用程序(函数雏形)
类似R中的Function,不过这里可以完整将代码存在一个函数里面,下次可以重复调用。
- % macro test;
- data a2;
- X=1;
- run;
- %mend test;
- %test;
%macro test; 以及 %mend test; 代表着宏程序的开始与结尾,下次调用的话,就直接%test;即可。
不过,要下次开机之后再用的话,必须地永久得对宏进行存储,就像函数一样。
存储的代码:
- /*存储宏程序*/
- libname test '';
- options mstored sasmstore=test;
- % macro test/store;
- data a2;
- X=1;
- run;
- %mend test;
- /*调用宏程序*/
- libname test '';
- options mstored sasmstore=test;
- %test;
其中,options mstored sasmstore=宏名称; 是关键,同时,% macro test/store;存储时候中需要加入/store
3、宏参数——类函数
其实觉得宏程序其实没啥用,宏程序的升级版,宏参数才是最有用的,宏参数类似函数一样。
- %MACRO A;
- 1
- %MEND A;
- %MACRO B(x,y);
- %let z=%eval(&x+&y);
- %put &z;
- %MEND B;
- %B(13,%A);
来看看来自经管之家论坛一篇帖子的内容,我觉得把宏变量、宏参数演绎得淋漓尽致。
通过%macro %mend把A定义为1,以便可以复用;
然后%eval把字符型值变成数值型(关于这个需要深究一下,还有%str的用法)。
其中%B就代表调用函数,然后进行计算。
——————————————————————————————————————————————————————————
三、统计量
对数据集的操作。
- data m15;set m14;
- data1=nobs**2;/*乘方用**表示*/
- data2=int(size);/*int:取整*/
- data3=ceil(size);/*返回大于等于变量的最小整数值*/
- data4=floor(size);/*返回小于等于变量的最大整数值*/
- data5=sqrt(data1);/*平方根*/
- data6=exp(nobs-1);/*e的x次方*/
- data7=log10(asset);/*以10为底的对数*/
- data8=round(size,0.01);/*保留2位小数后的四舍五入结果*/
- data9=mod(nobs,2);/*求前者除以后者的余数*/
- data10=sign(log(mv)-log(asset));/*符号函数,对正数返回1,0返回0,负数返回-1*/
- data11=max(log(mv),log(asset));
- data12=min(log(mv),log(asset));
- run;
里面包括:乘方、取整、平方根、指数、对数、最大、最小值。
每每以为攀得众山小,可、每每又切实来到起点,大牛们,缓缓脚步来俺笔记葩分享一下吧,please~
———————————————————————————
SAS︱操作语句(if、do、select、retain、array)、宏语言、统计量、运算符号的更多相关文章
- sql 数据库操作语句 不带select
MySQL数据操作语句 1.总纲 DDL -数据定义语句** create/drop/alter ** create: 创建 drop:删除 alter:修改 DML -数据操作语句 ** inser ...
- Oracle手边常用命令及操作语句
Oracle手边常用命令及操作语句 作者:白宁超 时间:2016年3月4日11:24:08 摘要:日常使用oracle数据库过程中,常用脚本命令莫不是用户和密码.表空间.多表联合.执行语句等常规操作. ...
- mysql常用操作语句
mysql常用操作语句 1.mysql -u root -p 2.mysql -h localhost -u root -p database_name 2.列出数据库: 1.show datab ...
- LINQ to SQL语句(2)之Select/Distinct
适用场景:o(∩_∩)o- 查询呗. 说明:和SQL命令中的select作用相似但位置不同,查询表达式中的select及所接子句是放在表达式最后并把子句中的变量也就是结果返回回来:延迟.Select/ ...
- SQL 四种基本数据操作语句的基本使用
SQL中含有四种基本的数据操作语句,分别是增(INSERT),删(DELETE),查(SELECT),改(UPDATE).下面简单介绍这四种语句的用法. 1:增(INSERT) 可分为两种查询情况,一 ...
- mongodb 操作语句与sql操作语句对比
上行:SQL 操作语句 下行:Mongo 操作语句 CREATE TABLE USERS (a Number, b Number) db.createCollection("mycoll&q ...
- LINQ to SQL 语句(2)之 Select/Distinct
LINQ to SQL 语句(2)之 Select/Distinct [1] Select 介绍 1 [2] Select 介绍 2 [3] Select 介绍 3 和 Distinct 介绍 Se ...
- MySql常用操作语句(1:启动、连接数据库及用户操作)
下方将个人常用的MySql操作语句(Win7下)总结如下: 1. 启动与关闭数据库 “管理员”权限, MySql安装目录下bin目录//: 1.1 启动 @>net start mysql ...
- 【MySQL】MySQL基础操作语句
mysql基础操作语句,包括数据库的增.删.切换,以及表的增.删.改.查.复制. 创建数据库 mysql> create database tem; 使用数据库 mysql> use te ...
随机推荐
- 使用postMessage实现跨域 解决'Failed to execute 'postMessage' on 'DOMWindow''
使用iframe+postMessage解决跨域问题,首先来过一遍其中的原理咯 原理: 发送方使用postMessage方法向接收方推送消息,第一个参数为推送的内容,第二个参数是允许被访问的域名: 接 ...
- 编译和解释性语言和python运行方式
1.编译型语言和解释性语言 编译型语言:在执行之前需要一个专门的编译过程,把程序编译成为机器语言的文件,运行时不需要重新翻译,直接使用编译的结果就行了.程序执行效率高,依赖编译器,跨平台性差些.如C. ...
- c#实现Word转换PNG图片
由于项目需要,经过一些大神的指导以及github,stackOverflow找资料,写了个这么个程序. 主要是因为word文档有特殊字体,特殊字体处理就要用到EnhMetaFileBits,即获取一页 ...
- 安装linux下面用来配置网络,防火墙,系统服务等设置的图形小工具Setup
Setup命令是linux下面用来配置网络,防火墙,系统服务等设置的图形小工具.使用起来非常方便简单,可是centos\redhat最小化安装之后发现setup命令工具用不了. 接下来介绍如何安装se ...
- python学习--Linux下dlib安装(主要是cmake和boost的安装)
昨天我们使用了dlib和opencv进行了人脸检测标注(http://www.cnblogs.com/take-fetter/p/8310298.html) 但是运行环境是基于windows的而且可能 ...
- jboss7.1.1相关error及解决办法
问题1: 报错提示: 公司的网站系统使用的中间是jboss7.1.1 Final,由于有些数据和服务测试环境不具备,免不了要在测试环境调试些jsp页面,发现从jboss社区里下载的jboss应用有个问 ...
- java web 获取客户端操作系统信息
package com.java.basic.pattern; import java.util.regex.Matcher; import java.util.regex.Pattern; /** ...
- 自动化测试selenium(四)check,选中复选框,操作一组元素
定位复选框位置 打开浏览器,按F12,审查元素 接下来,我们要实现选中复选框 List<WebElement> inputs = driver.findElements(By.tagNam ...
- mysql 军规 (转载)
导语 来自一线的实战经验 每一条军规背后都是血淋淋教训 不要华丽,只要实用 若有一条让你受益,慰矣 主要针对数据库开发人员 总是在灾难发生后,才想起容灾的重要性 总是在吃过亏后,才记得曾经有人提醒过 ...
- 发送POST测试请求的若干方法
最近在工作中需要测试发送带Json格式body值的HTTP POST请求.起初,我在Linux环境下使用curl命令去发送请求,但是,在发送的过程中却遇到了一些问题,经过一段时间的摸索,发现了以下几种 ...