SAS︱操作语句(if、do、select、retain、array)、宏语言、统计量、运算符号

2023-12-21 03:38

本文主要是介绍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)、宏语言、统计量、运算符号的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/518515

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

C++实现封装的顺序表的操作与实践

《C++实现封装的顺序表的操作与实践》在程序设计中,顺序表是一种常见的线性数据结构,通常用于存储具有固定顺序的元素,与链表不同,顺序表中的元素是连续存储的,因此访问速度较快,但插入和删除操作的效率可能... 目录一、顺序表的基本概念二、顺序表类的设计1. 顺序表类的成员变量2. 构造函数和析构函数三、顺序表

使用C++实现单链表的操作与实践

《使用C++实现单链表的操作与实践》在程序设计中,链表是一种常见的数据结构,特别是在动态数据管理、频繁插入和删除元素的场景中,链表相比于数组,具有更高的灵活性和高效性,尤其是在需要频繁修改数据结构的应... 目录一、单链表的基本概念二、单链表类的设计1. 节点的定义2. 链表的类定义三、单链表的操作实现四、

Python利用自带模块实现屏幕像素高效操作

《Python利用自带模块实现屏幕像素高效操作》这篇文章主要为大家详细介绍了Python如何利用自带模块实现屏幕像素高效操作,文中的示例代码讲解详,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、获取屏幕放缩比例2、获取屏幕指定坐标处像素颜色3、一个简单的使用案例4、总结1、获取屏幕放缩比例from