`
ethen
  • 浏览: 122277 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

SAS 简单的宏编写

    博客分类:
  • SAS
阅读更多

    作为SAS初学者,在遇到具体的问题时,真是想不到一些比较好的解决办法,幸好有同事帮忙。最近遇到个问题,具体内容是A表中有(item_id,key,val_z,vla_m,val,date),其中date格式为‘201001’,date范围是‘201001-201009’,而val=val_z/val_m,要求计算每连续三个月的val的值,然后从7(因为是9个月,所以最终得到7个值)个val中取出一个最大值作为最后结果。

    具体编码如下:

data sumcnad01;                                                                                                                                    
set sub_jhcb.sumcnad01;                                                                                                                            
where date_t>='201001' and date_t<='201009';                                                                                                       
run;                                                                                                                                               
                                                                                                                                                   
                                                                                                                                                   
data temp1(keep=item_id jhz_key val_z val_m date_t);                                                                                               
set sumcnad01;                                                                                                                                     
run;                                                                                                                                               
                                                                                                                                                   
data tmpresult(keep=item_id jhz_key val);                                                                                                          
set sumcnad01;                                                                                                                                     
where 1<>1;                                                                                                                                        
run;                                                                                                                                               
                                                                                                                                                   
/*计算201001-201009*/                                                                                                                              
%macro best;                                                                                                                                       
%let startmonth=200912;                                                                                                                            
                                                                                                                                                   
%do i=1 %to 7;                                                                                                                                     
data _null_;                                                                                                                                       
     call symput("startmonth",substr(compress(put(intnx('month',input("&startmonth"||'01',yymmdd10.),+1),yymmdd10.),'-'),1,6));                    
run;                                                                                                                                               
data _null_;                                                                                                                                       
     call symput("endmonth",substr(compress(put(intnx('month',input("&startmonth"||'01',yymmdd10.),+3),yymmdd10.),'-'),1,6));                      
run;                                                                                                                                               
                                                                                                                                                   
proc sql;                                                                                                                                          
      create table temp2 as                                                                                                                        
      select distinct item_id,jhz_key,(sum(Val_z)/sum(Val_m)) as Val                                                                               
      from temp1                                                                                                                                   
      where date_t >= "&startmonth" and date_t <= "&endmonth"                                                                                      
      group by item_id,jhz_key;                                                                                                                    
quit;                                                                                                                                              
                                                                                                                                                   
                                                                                                                                                   
proc append base=tmpresult data=temp2 force;quit;                                                                                                  
                                                                                                                                                   
%end;                                                                                                                                              
                                                                                                                                                   
%mend best;                                                                                                                                        
                                                                                                                                                   
%best;                                                                                                                                             
                                                                                                                                                   
proc sql;                                                                                                                                          
create table result as                                                                                                                             
select item_id,jhz_key,max(val) as bestval                                                                                                         
from  tmpresult                                                                                                                                    
group by item_id,jhz_key;                                                                                                                          
quit;                              
 

 通过此次编码,了解了SAS宏编程的初步知识,也对intnx这个函数有了一定的理解。

分享到:
评论

相关推荐

    软件SAS宏编程

    SAS宏编程是指在SAS系统中使用宏处理器和宏语言来...SAS宏编程可以极大地提高SAS程序的灵活性和可重用性,同时减少重复编写相似代码的需要。掌握SAS宏编程是SAS程序员进阶的重要步骤,也是他们必须掌握的高级技能之一。

    sas宏语言基础

    - **宏变量**:以&标识,用于存储和传递值,宏变量在宏语言中起着关键作用,支持文本替换功能,相对于普通变量,其功能较为简单,但应用范围广泛。 ##### 3. SAS宏工具的功能结构 SAS宏工具的核心组件包括: - **...

    SAS宏_经典教程_2007年第二版_

    - **目标读者**:适合具备基础到中级SAS语言程序编写经验的学习者,无需预先了解SAS语言和编程概念。 #### 二、书籍结构与内容安排 - **第一部分**:介绍宏编程语言的基本元素和机制。 - **重点内容**:宏观概述...

    SAS语言的宏功能.pdf

    宏变量的值可以是简单的字符串,也可以是一段完整的SAS代码。这种灵活性使得宏变量成为处理动态数据和代码的强大工具。 - **最大长度**: 宏变量的值的最大长度为65534个字符。 - **长度自动调整**: 宏变量的长度...

    SAS Macro Make it easy

    SAS宏的例子包括:通过一个简单的宏命令来格式化输出,或者通过传递参数创建灵活的报表。 在了解了SAS宏的基本概念后,我们可以进一步探讨宏处理(Macro Processing)的机制。SAS处理过程可以分为无宏活动(SAS ...

    SAS Certification Prep Guide-Advanced Programming for SAS9

    5. **数据可视化**:SAS的图形生成能力非常强大,从简单的柱状图到复杂的热图,书中会教授如何利用PROC GPLOT和PROC SGPLOT创建专业图表。 6. **程序控制结构**:条件语句(IF-THEN/ELSE,WHERE)、循环(DO-WHILE...

    SAS.Publishing.SAS.Macro.Programming.Made.Easy.2nd.Edition.Mar.2007

    4. **编写宏代码的方法**:采用逐步开发的方式,先从简单的例子入手,逐渐扩展到更复杂的场景。 #### 四、新增内容与更新 1. **SAS 9 特性**:本书针对SAS 9环境进行了更新,包括新特性介绍和示例。 2. **宏编程...

    SAS.9.2.Macro.Language.Reference.rar_SAS Macro Language _macro l

    SAS宏语言是SAS系统中的一个强大工具,它允许用户编写可重用的代码段,以提高效率和代码的可维护性。在SAS 9.2版本中,宏语言的功能得到了进一步增强,提供了更丰富的控制结构和更强大的编程能力。这份名为"SAS.9.2....

    约翰霍普金斯 SAS课件

    5. **宏编程**:SAS宏语言使得编写重复性的或复杂的程序变得简单。掌握宏变量、宏函数及宏条件语句,可以提高工作效率,实现程序的可重用性。 6. **SAS环境管理**:了解如何组织工作空间、创建和管理库,以及如何...

    sas考试资料

    1. **SAS基础**:介绍SAS环境,包括SAS Studio或SAS EG等界面,以及如何创建和运行简单的SAS程序。 2. **数据步(Data Step)**:讲解如何在SAS中读取、创建、修改和处理数据集,包括数据步的基本结构、变量定义、...

    SAS® 9.1 Macro Language.pdf

    这一章深入探讨了SAS程序与宏处理之间的关系,包括SAS如何处理没有宏活动的简单程序,以及当引入宏功能后,SAS的处理流程会发生哪些变化。 - **无宏处理的SAS程序**:介绍SAS如何按顺序执行每个语句。 - **宏处理**...

    sas简明版教程

    - **代码简洁**:SAS语言易于编写且高效。 3. **数据连续处理能力** - **数据集成**:可以从多个数据集中组合变量值和观测值,创建子集,连接、合并和修改数据集。 - **多文件处理**:同时处理多个输入文件,...

    SAS tutor

    SAS宏语言是SAS系统中的一个重要组成部分,它允许用户编写自定义的程序块,实现代码复用和程序自动化,提高工作效率。 6. **SAS编程** 学习SAS编程,需要理解数据步(Data Step)和过程步(Procedure Step)的...

    sas学习的代码.zip

    SAS宏是一种预处理工具,允许用户编写可重用的代码块,提高工作效率。宏变量可以动态地存储和传递信息,宏语句则可以控制程序流程,实现复杂逻辑。通过研究这些代码,你可以学习到如何构建宏、定义宏变量以及使用...

    SAS/MACRO

    通过实践和编写宏程序,能够提升SAS编程的灵活性和效率,尤其在处理复杂的数据处理任务时更为显著。 最后,关于提供的压缩文件`macr8.zip`,虽然没有具体内容,但通常包含的可能是SAS/MACRO的示例代码或教程。解压...

    sas学习资料

    - 研究数据步和过程步的语法,尝试编写简单的SAS程序。 - 实践导入和导出数据,熟悉数据管理操作。 - 通过SAS/STAT学习统计分析方法,结合实际案例理解应用。 - 利用SAS/GRAPH制作图表,提升数据可视化能力。 -...

    SAS V8基础教程(上)

    在《SAS V8基础教程(上)》中,你还会接触到数据处理的高级概念,比如宏语言(Macro Language),它允许用户编写可重用的代码段,提高工作效率。宏变量和宏函数是宏语言的核心,它们可以用来动态生成SAS代码。 ...

    sas最优化软件速成

    4. **基本编程**:学习如何编写简单的SAS程序,包括数据步(Data Step)、流程步(Proc Step)等核心概念。数据步主要用于数据的读取、处理和保存;流程步则负责执行统计分析任务。 #### 三、OR-SAS优化算法实例解析 1....

Global site tag (gtag.js) - Google Analytics