继续读书笔记,本文重点侧重sas观测值的操作方面, 主要包括:输出观测值、更新观测值、删除观测值、停止输出观测值等

1.output语句   输出当前在pdv中的观测值,继续无条件执行下面的语句。

注意:简单的data步不需要output语句,run语句会自动输出pdv中的数据到数据集,并返回data步开头继续执行下一条观测。

在有output语句和run语句同时存在时,pdv只会执行output的结果到正在被创建的数据集,而执行run语句的结果是pdv会清空所有的变量值为缺失值

data a;

input id x1-x3;

cards;

101 10 20 30

102 40 50 60

;

data b;

set a;

x=x1;output;

x=x2;output;

x=x3;output;

output;

run;

由于data步包含四个output语句,因此每次读入一条观测,程序会执行output语句,总共会输出8条记录

data out1 out2;

set sashelp.class;

if _n_ le 7 then output out1;

else output out2;

run;

if条件的output语句,只有满足if条件时pdv才把得到的结果输出到正在被创建的数据集

data a;

input x y @@;

cards;

1 10 1 20 1 200 2 30 2 40

3 50 3 60 4 70 3 80 4 400

;

proc sort data=a;by x;run;

data b;

set a;

by x;

retain rt;

if first.x then rt=0;

if last.x then output;

rt=y;

run;

输出by变量的last观测值,并保留last最近前一条观测变量值。

该例中output与run同时出现时,值输出output后面的,不管output前面的条件是否成立;执行run语句的结果是PDV会清空所有的变量值为缺失。

是对每一个by组进行循环的,且first.x也是针对by组的

2.if语句 是一个可执行语句,将满足条件的观测值输出到正在被创建的数据集中

3.where语句  不是一个可执行语句,判断条件是在pdv之前

注:不能使用自动变量_n_或者其他选项如obs,point与where语句一起使用。因为where语句是在pdv之前

使用where语句必须保证读入数据集的完整性,不能使用如firstobs=2等不能完整读入数据集的选项

对同一数据集,同时使用where语句和where=选项,则系统只使用where=选项,而不考虑where语句

where语句和by语句一起出现时,先执行where语句,然后在by语句,by组对执行完毕后的数据集重新定义first/last

Where语句和if语句 区别

1.where语句是在观测进入pdv之前起作用,而if语句是在pdv中的观测起作用。

2.where语句不是一个可执行语句,而子集if语句是可执行语句

3.where语句有自己特有的表达式,而if语句使用通用的sas表达式

4.where语句比if效率高

4.replace语句和remove语句和output语句

这两个语句只能跟modify一起使用,

数据集:

libname chapt5 "f:\data_model\book_data\chapt5";

data chapt5.a;

input x y @@;

cards;

1 10 2 20 3 30 4 40

;

run;

libname chapt5 "f:\data_model\book_data\chapt5";

data chapt5.b;

input x y @@;

cards;

3 300 4 400 5 500

;

run;

eg:

data chapt5.a;

modify chapt5.a chapt5.b;

by x;

if _iorc_=0 then replace;

else _error_=0;

run;

对匹配到的数据,更新数据集将覆盖主数据集,对于未匹配到的数据,不予考虑

data chapt5.a;

modify chapt5.a chapt5.b;

by x;

if _iorc_=0 then replace;

else do; _error_=0;output;end;

run;

对匹配到的数据,更新数据集将覆盖主数据集,对于未匹配到的数据,将更新数据集数据也输出到主数据集中

data chapt5.a;

modify chapt5.a chapt5.b;

by x;

if _iorc_=0 then remove;

else _error_=0;

run;

对于匹配到的数据从主数据中删除

5.delete语句和stop语句

data a;

set sashelp.class;

if sex eq "M" then delete;

run;

删除部分观测,以下代码目的一样

data a;

set sashelp.class;

if sex ne "M";

run;

data a;

set sashelp.class;

if _n_ ge 3 then stop;

run;

stop直接跳出data,最终数据集a只有两条观测

《SAS编程与数据挖掘商业案例》学习笔记之十一相关推荐

  1. SAS学习笔记之《SAS编程与数据挖掘商业案例》(4)DATA步循环与控制、常用全程语句、输出控制...

    SAS学习笔记之<SAS编程与数据挖掘商业案例>(4)DATA步循环与控制.常用全程语句.输出控制 1. 各种循环与控制 DO组 创建一个执行语句块 DO循环 根据下标变量重复执行DO和E ...

  2. 《SAS编程与数据挖掘商业案例》学习笔记之十九

    继续<SAS编程与数据挖掘商业案例>学习笔记,本文侧重数据处理实践,包括:HASH对象.自定义format.以及功能强大的正则表达式 一:HASH对象 Hash对象又称散列表,是根据关键码 ...

  3. 《SAS编程与数据挖掘商业案例》学习笔记之十六

    <SAS编程与数据挖掘商业案例>学习笔记,本次重点:sas宏变量 内容包括:宏变量.宏函数.宏参数.通配函数.字符函数.计算函数.引用函数.宏语句.宏应用 1.宏触发器: %name-to ...

  4. 《SAS编程与数据挖掘商业案例》学习笔记之十四

    继续<SAS编程与数据挖掘商业案例>学习笔记系列,本次重点:常用全程语句 所谓全程语句,是指可以用在任何地方的sas语句,既可以用在data数据步语句里面,也可以用在proc过程步里面,甚 ...

  5. SAS学习笔记之《SAS编程与数据挖掘商业案例》(3)变量操作、观测值操作、SAS数据集管理...

    SAS学习笔记之<SAS编程与数据挖掘商业案例>(3)变量操作.观测值操作.SAS数据集管理 1. SAS变量操作的常用语句 ASSIGNMENT 创建或修改变量 SUM 累加变量或表达式 ...

  6. SAS学习笔记之《SAS编程与数据挖掘商业案例》(2)数据获取与数据集操作

    SAS学习笔记之<SAS编程与数据挖掘商业案例>(2)数据获取与数据集操作 1. SET/SET效率高,建立的主表和建表索引的查询表一般不排序, 2. BY语句,DATA步中,BY语句规定 ...

  7. SAS学习笔记之《SAS编程与数据挖掘商业案例》(3)变量操作、观测值操作、SAS数据集管理

    SAS学习笔记之<SAS编程与数据挖掘商业案例>(3)变量操作.观测值操作.SAS数据集管理 1. SAS变量操作的常用语句 ASSIGNMENT 创建或修改变量 SUM 累加变量或表达式 ...

  8. 《SAS编程与数据挖掘商业案例》学习笔记之十五

    继续<SAS编程与数据挖掘商业案例>读书笔记,本次重点:输出控制 主要内容包含:log窗体输出控制.output窗体输出控制.ods输出控制 1.log窗体输出控制 将日志输出到外部文件 ...

  9. 《SAS编程与数据挖掘商业案例》学习笔记之十八

    接着以前的<SAS编程与数据挖掘商业案例>,之前全是sas的基础知识,现在开始进入数据挖掘方面笔记,本文主要介绍数据挖掘基本流程以及应用方向,并以logistic回归为例说明. 一:数据挖 ...

  10. 《SAS编程与数据挖掘商业案例》学习笔记之十七

    继续读书笔记,本次重点sas sql语句,因为sql内容多且复杂,本文仅仅介绍商业应用中经常使用的而且easy出错的地方,内容包含:单表操作.多表关联.子查询以及merge和join的差别 1.单表操 ...

最新文章

  1. Java进程占用内存超高分析
  2. 绝悟之后再超神,腾讯30篇论文入选AI顶会ACL
  3. 更改matlab默认启动路径
  4. (1).数据结构概述
  5. 倒计时小工具_这款高颜值的 APP 可以让小仙女/男神们的日子过得更精致
  6. s8050三极管经典电路_曝光一个产品级的红外发射电路
  7. python selenium截图_python+selenium截图操作样例
  8. 目前服务器操作系统版本,目前服务器操作系统版本号
  9. springcloud maven打包部署
  10. [过年菜谱之]杭椒牛柳
  11. poj_3628 动态规划
  12. ssh工作流程及原理
  13. 医院HIS预约系统源码丨同城排队预约下单微信小程序公众号 his源码
  14. 创建一个urdf机器人_ROS机器人Diego 1#制作(十六)创建机器人的urdf模型描述文件详解...
  15. python自然语言_Python自然语言处理 - 随笔分类 - 牛皮糖NewPtone - 博客园
  16. 二维条形码概念 | 二维码的知识与历史介绍 | 鸿顺捷知识分享
  17. 只用js代码实现电子时钟,精确到毫秒
  18. php创作原声,抖音这是发小哥哥的唯一号创作的原声什么歌 I keep saying no歌曲分享...
  19. 微笑识别(HOG+SVM+opencv+python)
  20. HTTP Content-type 对照表

热门文章

  1. 阿里如何应对亿级高并发大流量?如何保障高可用和稳定性!
  2. .NET Core 3.0中IAsyncEnumerableT有什么大不了的?
  3. .net core i上 K8S(六).netcore程序的service网络代理模式
  4. 领域驱动设计,让程序员心中有码(二)
  5. 解决C# 7.2中的结构体性能问题
  6. CoreCLR源码探索(八) JIT的工作原理(详解篇)
  7. 弹性和瞬态故障处理库Polly介绍
  8. .NET Core运行时和基础类库性能提升
  9. 剑英的区块链学习手记(二)
  10. ASP.NET Core 开发-Entity Framework (EF) Core 1.0 Database First