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

《SAS编程与数据挖掘商业案例》学习笔记,本次重点:sas宏变量

内容包括:宏变量、宏函数、宏参数、通配函数、字符函数、计算函数、引用函数、宏语句、宏应用

1.宏触发器:

%name-token:是一个宏语句或宏函数

&name-token:是一个宏变量引用

宏变量不依赖于sas数据集,可以在任何一个除数据行以外的地方定义和引用宏变量,一般定义的宏变量为局部变量,除非使用%global,定义宏变量用%let,显示宏变量用%put,调用宏变量用&

eg

%let a=xxx;

%put &a;

%put here is &a;

Eg:带引号的文本中引用宏变量

%let var=ddd;

Data a;

X="here is &var.";

run;

如果要正确引用宏变量var值,必须用双引号而不是单引号括住该文本,因为宏处理器只能在双引号中进行替换。

 

proc sql;

create table temp as

select *

from sashelp.class

where sex like '%M%'

;

quit;

eg:间接引用宏变量

%let mvar=here;

%let x=10;

%put &&mvar.&x ;

当程序读到第一个&时,立刻启动宏触发器,由于存在句点号,故宏处理器会接受两个宏变量&mvar&x

2.宏函数

libname test ' f:\data_model\book_data\chapt10';

options mstored sasmstore=test;

%macro test / store ;   *是定义宏的关键字

 data a;

x=1;

run;

%mend test;  是宏定义结束的标识

宏存储,会将宏生成到相应目录下面的sasmar文件里面,

调用永久存储的宏:

libname test ' f:\data_model\book_data\chapt10';

options mstored sasmstore=test;

%test;

3.宏参数

宏功能强大之处在于宏参数,定义宏参数有两种方法,

按值创建宏参数:

%macro value(x=,y=);

data test;

x=&x.;

y=&y.;

run;

%mend value;

调用:

%value(x=10,y=20);

按地址创建宏参数

%macro addr(x,y);

data test;

x=&x.;

y=&y.;

run;

%mend addr;

调用:

�dr(10,20);

4.通配函数

是指能够在sas宏中引用data步的函数,最常用的通配函数是%sysfunc

Eg;

%num=10;

%let x=%sysfunc(trim(%sysfunc(left(&num))));

%put &x;

Eg:translate函数应用

%let string1 = v01n01-v01n10;

%let string1 = %sysfunc(translate(&string1,p, n));

%put with n translated to p, v01n01-v01n10 is &string1;

eg:判断数据集是否存在

%let dsn=%sysfunc(exist(sashelp.class));

%put &dsn;

5.计算函数

宏计算函数有两个:

%EVAL:计算算术和逻辑表达式(整数格式)

%SYSEVALF:计算算术和逻辑表达式(浮点格式)

Eg:

%let a=1 2;

%let b=10*3;

%let c=5/3;

%let eval_a=%eval_r(&a);

%let eval_b=%eval_r(&b);

%let eval_c=%eval_r(&c);

 

%put &a is &eval_a;

%put &b is &eval_b;

%put &c is &eval_c;

Eg:函数累加器

%macro test(finish);

   %let i=1;

   %do %while (&i<&finish);

      %put the value of i is &i;

      %let i=%eval_r(&i 1);

   %end;

%mend test;

%test(5)

eg

%sysevalf(1/3,boolean)     

%sysevalf(10 .,boolean)    

 

%sysevalf(1 1.1,ceil)      

%sysevalf(-1 -2.4,ceil)      

%sysevalf(-1 1.e-11,ceil)  

%sysevalf(10 .)          

 

%sysevalf(-2.4,floor)         

%sysevalf(3,floor)           

%sysevalf(1.-1.e-13,floor)    

%sysevalf(.,floor)          

 

%put %sysevalf(2.1,integer);       

%put %sysevalf(-2.4,integer);      

%put %sysevalf(3,integer);         

%put %sysevalf(-1.6,integer);      

%put %sysevalf(1.-1.e-13,integer); 

6.字符函数

%index

返回一个字符串第一次出现的位置

%length

返回自变量长度

%QSCAN

扫描单词,并引用包括%&的结果

%QSUBSTR

提取包括%&的子串,并引用包括%&的结果

%QUPCASE

转换包括%&的小写字符为大写

%SCAN

扫描单词,并返回一个结束引用的结果

%substr

提取子串,并返回一个结束引用的结果

%upcase

转换小写字符为大写字符,并返回一个结果引用的结果

Eg:

%macro a;

   aaaaaa

%mend a;

%macro b;

   bbbbbb

%mend b;

%macro c;

   cccccc

%mend c;

 

%let x=%nrstr(%a*%b*%%c);

%put X: &x;

%put The third word in X, with SCAN: %scan(&x,3,*);

%put The third word in X, with QSCAN: %qscan(&x,3,*);

7.引用函数

%nrstr

引用固定文本,包括&%

%str

引用固定文本,不包括&%

%quote

引用一个可分辨的值,不包括%&

%nrbquote

引用一个可分辨的值,包括未处理的特殊符号,&%sas操作符

%nrquote

引用一个可分辨的值,包括未处理的特殊字符

eg

%macro x;

xxxxx;

%mend x;

%put : The result of str is :%str(%x);

%put: The result of nrstr is :%nrstr(%x);

eg

%macro dept2(state);

   %if %quote(&state)=nc %then

       %put north carolina department of revenue;

   %else %if %quote(&state)=%str(or) %then

       %put department of revenue;

   %else %put others;

%mend dept2;

�pt2(or)

调用�pt2(or)后,参数state获得值or,由于在sas系统里面or是一个逻辑操作符,所以为了得到纯文本含义的or,只能用%quote

8.宏语句

eg

%macro obs(parm);

   %let parm1 = %upcase(&parm);

   %if &parm1 = PRE %then

      %do;

         data pre_obs;

            set sashelp.class(obs=5);

    if sex="M" then y=1;

    else y=2;

         run;

      %end;

   %else %if &parm1 = POST %then

      %do;

         data post_obs;

            set sashelp.class(firstobs=6);

    if sex="M" then y=1;

    else y=2;

         run;

      %end;

%mend obs;

%obs(pre);

eg

%macro dow();

%let i=1;

%do %while (&i<5) ;

%let i=%eval_r(&i. 1); 

%put &i.;

%end;

%mend dow;

%dow;

eg:搜寻子字符串并输出

%macro dw(word);

%let i=1;

data out;

%do %while (%left(%scan(&word.,&i.)) ne %nrbquote(stop));

%let var=%scan(&word.,&i.);

%put &var.;

out="&var";

output;

%let i=%eval_r(&i. 1);

%put &i.;

%end;

run;

%mend dw;

%dw(%str(test1,test2,test3));

9.宏应用

eg:通过sql过程创建多个宏变量

proc sql noprint;

   select nvar,nobs

   into:nvar , :nobs

   from dictionary.tables

   where libname = 'SASHELP' and memname = 'CLASS';

 

quit;

%put &nvar.;

%put &nobs.;

eg:通过sql过程用变量名创建宏变量列表

proc sql noprint;

  select name

  into :clist1-:clist999

  from dictionary.columns

  where libname = 'SASHELP' and memname = 'CLASS';

quit;

%put &clist1.;

%put &clist2.;

eg:通过data步接口子程序call symputx

data _null_;

set sashelp.class nobs=obs;

call symputx('m1',obs);

call symput('m2',obs);

Stop;

run;

%put &m1.;

%put &m2.;

注:symputx能消除后面参数的左右空格,而symput只能消除右空格。

eg:重命名指定目录下的sas数据集名称

libname chap10 "f:\data_model\book_data\chapt10";

%let rpt=rpt_temp;

proc sql;

create table chap10.change_tb_name as

select

memname

from dictionary.tables

where libname eq "CHAP10";

quit;                                                 *上面主要是产生指定目录下所有sas数据集名称

%macro change();

%let dsid=%sysfunc(open(chap10.change_tb_name));                  1)打开数据集,每行运行一次open,并返回id给宏变量dsid

%if &dsid gt 0 %then %do;                                                                   2)对返回的id号判断,若成功打开数据集,则id肯定非0,则执行do语句

%let nobs=%sysfunc(attrn(&dsid,nobs));                                          3)抓取数据集的观测数,返回一个数值

%do i=1 %to &nobs;                                                                              4)执行5次循环

%let rc=%sysfunc(fetchobs(&dsid,&i));                                   5)抓取对于的观测

%let varnume=%sysfunc(varnum(&dsid,memname));         6)找到memname所在的列位置

%let table=%sysfunc(getvarc(&dsid,&varnume));                 7)抓取memname对应位置的值

proc datasets lib=chap10;                                                       8)利用每个返回的值,执行datasets过程步,改变相应数据集的名称

change &table=&rpt._t&i.;

quit;

%end;                                                                                                     9)结束%do语句

%let dsid=%sysfunc(close(&dsid));                                                 10)关闭数据集

   %end;                                                                                                         11)

%mend change;

%change;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/293519.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# ActionT和 FuncT委托

除了为每个参数和返回类型定义一个新委托类型之外&#xff0c;还可以使用 Action<T> 和 Func<T>委托。泛型 Action<T>委托表示引用一个 void 返回类型的方法。这个委托类存在不同的变体&#xff0c;可以传递至多 16 种不同的参数类型。没有泛型参数的 Action…

linux学习-简单命令介绍及安装VMware Tools

常用简单命令介绍 ethernet以太网pts&#xff1a;模拟终端图形界面&#xff1a;CtrlAltF1 字符界面&#xff1a;CtrlAltF2-F6切换虚拟终端&#xff1a;&#xff08;本机操作&#xff09;# chvt 1-6关闭图形界面,在纯字符界面下操作&#xff1a; init 3打开图形界面&#xff…

Android之6.0 权限申请封装

之前一篇博客初试了Android6.0系统的动态权限申请&#xff0c;成功之后开始思考将权限申请功能封装以供更加方便的调用。 查阅6.0系统权限相关的API&#xff0c;整个权限申请需要调用三个方法&#xff1a; 1. ContextCompat.checkSelfPermission() 检查应用是否拥有该权限&a…

Samba服务器问题汇总

一个Samba服务器要么经典模式访问&#xff08;用户名密码&#xff09;&#xff0c;要么友好访问&#xff08;guest&#xff09;&#xff0c;只可选其一。㈠准备工作&#xff1a;1>清除客户端windows系统的上次访问自动记录CMD下运行&#xff1a;net use * /delete /y2>关…

Unity手游之路lt;七gt;角色控制器

我们要控制角色的移动&#xff0c;能够所有细节都由自己来实现。控制角色模型的移动&#xff0c;同一时候移动摄影机&#xff0c;改变视角。当然Unity也提供了一些组件&#xff0c;能够让我们做更少的工作&#xff0c;实现我们所期望的功能。今天我们就一起系统来学习相关的内容…

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

接着以前的《SAS编程与数据挖掘商业案例》&#xff0c;之前全是sas的基础知识&#xff0c;现在开始进入数据挖掘方面笔记&#xff0c;本文主要介绍数据挖掘基本流程以及应用方向&#xff0c;并以logistic回归为例说明。 一&#xff1a;数据挖掘综述 衡量一个数据挖掘模型价值的…

开源软件的痛点

| 作者&#xff1a;Bob Jiang| 编辑&#xff1a;刘雪洁| 责编&#xff1a;王玥敏| 设计&#xff1a;宋传琪开篇我是 Bob Jiang (个人博客&#xff1a;https://www.bobjiang.com/)&#xff0c;开源软件领域的新人。我从2018年加入区块链领域开始认识和了解开源。当时我创立了HiB…

【CodeForces 577C】Vasya and Petya’s Game

链接 某个数x属于[1,n]&#xff0c;至少询问哪些数y“x是否是y的倍数”才能判断x。找出所有质因数和质因数的幂即可。 #include<cstdio> #include<algorithm> #define N 1005 using namespace std; int n,pr[N],ans[N],cnt; int main(){scanf("%d",&…

Andorid之华为手机开发模式不打印日志

用华为手机测试程序是&#xff0c;eclipse的logcat不能打印日志&#xff0c;我按照网上说的方法打开了windows下面的show view 的logcat&#xff0c;日志有logcat但是日志不打印&#xff0c;调试程序必须要日志&#xff0c;最后终于搜到了这个调试方法&#xff0c;在手机拨号界…

SQLite入门之数据类型

2019独角兽企业重金招聘Python工程师标准>>> SQLite入门之数据类型 2011-05-23 16:47:47 来源&#xff1a;SeaYee 最近在开发一个可以记录日志的程序&#xff0c;要求效率高&#xff0c;需要能做简单的查询和统计。经过同事介绍&#xff0c;看上了SQLite。首先了解…

【Tika基础教程之一】Tika基础教程

一、快速入门 1、Tika是一个用于文本解释的框架&#xff0c;其本身并不提供任何的库用于解释文本&#xff0c;而是调用各种各样的库&#xff0c;如POI&#xff0c;PDFBox等。 使用Tika&#xff0c;可以提取文件中的作者、标题、创建时间、正文等内容&#xff0c;相比于java.io自…

它是世界上最轻的固体!1000℃下不会熔化,上过火星,还能进你家......

全世界只有3.14 % 的人关注了爆炸吧知识小果冻大难关开学了&#xff0c;8岁表妹逮着这个机会讹了我一大箱果冻&#xff0c;超模君糊里糊涂就进了这只神兽的套。今天估计是一口气吃了太多&#xff0c;腻了&#xff0c;一边用手敲着果冻一边问超模君&#xff1a;“这果冻这么软&a…

使用C#快速生成二维码 | 真正跨平台方案

前言二维码&#xff08;QR Code&#xff09;&#xff0c;与传统的一维码&#xff0c;比如条形码&#xff0c;二维码具有存储的数据量更大&#xff1b;可以包含数字、字符&#xff0c;及中文文本等混合内容&#xff1b;有一定的容错性&#xff08;在部分损坏以后还可以正常读取&…

Andorid之MediaPlayer和AudioTrack播放Audio的区别与联系

播放声音可以用MediaPlayer和AudioTrack&#xff0c;两者都提供了java API供应用开发者使用。虽然都可以播放声音&#xff0c;但两者还是有很大的区别的。 其中最大的区别是MediaPlayer可以播放多种格式的声音文件&#xff0c;例如MP3&#xff0c;AAC&#xff0c;WAV&#xff0…

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

继续读书笔记&#xff0c;本次重点sas sql语句&#xff0c;由于sql内容多且复杂&#xff0c;本文只介绍商业应用中常用的并且容易出错的地方&#xff0c;内容包括&#xff1a;单表操作、多表关联、子查询以及merge和join的区别 1.单表操作 eg1&#xff1a; Proc sql outobs10&a…

制作一个类似苹果VFL的格式化语言来描述UIStackView

在项目中总是希望页面上各处的文字&#xff0c;颜色&#xff0c;字体大小甚至各个视图控件布局都能够在发版之后能够修改以弥补一些前期考虑不周&#xff0c;或者根据统计数据能够随时进行调整&#xff0c;当然是各个版本都能够统一变化。看到这样的要求后&#xff0c;第一反应…

[Android] TextView 分页功能的实现

为什么80%的码农都做不了架构师&#xff1f;>>> 分页功能是阅读器类软件的基本功能之一, 也是自己之前写阅读器时遇到的第一个问题. 尝试了不少办法才解决, 现在把其中最容易实现的一个方法记录下来, 也方便大家参考. 基本思路如下: 从文件中读取 8000 个字符至缓冲…

把男朋友变成儿子你只需要一秒

1 别人以为的我▼2 幸好有监控&#xff0c;差点就没法和老婆解释了&#xff01;▼3 为了卖化妆品我已经不止一次假装我有一群舔狗了▼4 这么多年下来班主任的这些套路谁还不清楚呢&#xff1f;▼5 司机同志们注意啦要主动停车接受检查▼6 让男友变儿子你只需要一秒钟▼7 …