sas infile和filename

3.1 追加原始文件
原始数据可以使用以下的方法进行纵合并。
  • INFILE语句
  • FILENAME语句
  • FILEVAR=选项
  • 操作系统自身的技术
    首先,你可能要察看原始数据。可以用FSLIST过程。
    语法:
    PROC FSLIST FILE = file-specification;
    RUN;
    实际使用中,专门的编辑器,如UltraEdit之类的小软件,用来察看原始文件有着更多的便利。
    INFILE
    为了读取多个原始文件,可以使用多个INFILE语句。这样数据步会从第一个文件中读出一条记录,再到第二个文件读一条记录,以此类推,读完所有文件再返回第一个文件。如下图所示

    FILENAME
    你也可以使用FILENAME语句,对原始文件进行串联。如下图所示:

    FILENAME语法如下:
    FILENAME fileref ('external-file1'
    'external-file2' … 'external-filen');

    其中fileref是任何8位或以下的有效SAS名称。
    'external-file' 是数据文件的物理名。
    例如:
    filename Q1 ('Month1.dat' 'Month2.dat' 'Month3.dat');
    data firstq;
    infile Q1;
    input Flight $ Origin $ Dest $
    Date : date9.
    RevCargo : comma15.2;
    run;
    FILEVAR=
    使INFILE语句的FILEVAR=选项,它可以帮助你有条件的连接多个原始文件,如下图所示:

    语法:
    infile xxx filevar = NextFile;
    xxx 是任意的8位或以下的占位名,不是一个实际的文件名或者定义好的文件引用。SAS使用这个占位名在日志中报告处理信息。
    NextFile 存放原始数据文件名的变量。
    例如:
    data movingq;
    do I = 11,10,9;
    NextFile = "Month"!!put(I,2.)!!".dat";
    NextFile = compress(NextFile,' ');
    infile xxx filevar = NextFile;
    input Flight $ Origin $ Dest $ Date : date9.
    RevCargo : comma15.2;
    output;
    end;
    stop;
    run;
    这个例程把Month11.dat, Month10.dat, Month9.dat三个原始文件装入到movingq数据集中,从中我们可以学到几点:
    1. 需要使用STOP语句跳出数据步循环。
    2. COMPRESS函数删除了字符串中的空格,使"Month 9.dat"变成"Month9.dat"。
    3. 以上程序只在每个原始文件中读出头一条记录。
    使用END=选项,我们可以控制数据步读完整个原始文件。
    语法:
    INFILE file-specification END = variable;
    END=选项把是否到达输入文件结尾标志放进variable变量中,如果当前的输入没有到达文件尾,变量值为0;反之变量值为1
    该变量不会被写入到输出SAS数据集中。
    由此,完整的程序为:
    data movingq;
    do I = 11,10,9;
    NextFile = "Month"!!put(I,2.)!!".dat";
    NextFile = compress(NextFile,' ');
    do until (LastObs);
    infile xxx filevar = NextFile end = LastObs;
    input Flight $ Origin $ Dest $ Date : date9.
    RevCargo : comma15.2;
    output;
    end;
    end;
    stop;
    run;
    项目中经常用到如下技巧:
    data movingq;
    MonNum = month(today());
    MidMon = month(intnx(‘month’,today(),-1));
    LastMon = month(intnx(‘month’,today(),-2));
    do I = MonNum, MidMon, LastMon;
    NextFile = "Month"!!put(i,2.)!!".dat";
    NextFile = compress(NextFile,' ');
    do until (LastObs);
    infile xxx filevar = NextFile end = LastObs;
    input Flight $ Origin $ Dest $ Date : date9.
    RevCargo : comma15.2;
    output;
    end;
    end;
    stop;
    run;
    以上程序读出当月和之前两个月的原始数据。这里的重点是INTNX函数,如果我们直接用当前月-1,-2来得到前两个月,在1,2月时程序就会发生错误。INTNX作用是返回间隔某个时间端的时间。函数格式为:
    INTNX('interval',start-from,increment)
    'interval' 一个字符常量,或者是存放时间间隔单位的变量。表示间隔单位。
    start-from 表示日期,日期时间或者时间的SAS表达式,作为起始点。
    increment 一个正或者负整数,表示时间间隔的数量。
    函数细节可以查询SAS在线帮助。
    题外话,与考试无关。项目中用的更多的是读出一个路径下的同一类接口文件,简便方法是使用如下FILENAME。
    FILENAME cf_list PIPE 'dir c:|rawdata|cf????.dat /b';
    DATA cf_data;
    INFILE cf_list;
    LENGTH filename $20;
    INPUT filename $;
    INFILE in FILEVAR = filename END = LastFile;
    DO WHILE (LastFile = 0);
    INPUT ....
    ....
    ;
    OUTPUT;
    END;
    RUN;
    这段程序把c:|rawdata下面的所有cf0101.dat,cf0102.dat,...,cf????.dat读入cf_data数据集中。如果看不明白,说明以上的内容你还没有全部理解 :-)

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

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

相关文章

Java 多线程(六) synchronized关键字详解

多线程的同步机制对资源进行加锁,使得在同一个时间,只有一个线程可以进行操作,同步用以解决多个线程同时访问时可能出现的问题。 同步机制可以使用synchronized关键字实现。 当synchronized关键字修饰一个方法的时候,该方法叫做同…

java自动化_作为测试工程师进阶自动化选Java还是Python?

这是很多测试工程师从功能跨入自动化纠结的问题,今天本文带大家一探究竟。Java和Python一直都是两种很火的语言,用Python的一定觉得Python好,用Java的只觉得Java好。Java语言 VS Python语言Java自动化方法 VS Python自动化方法综上所述&…

Spring –添加Spring MVC –第2部分

在上一部分中,我们为经理和员工实现了控制器。 既然我们知道了自己的出路,我们将做很少(但仅做很少)更复杂的事情-任务和时间表的控制器。 因此,让我们从org.timesheet.web开始。 TaskController 。 首先创建一个类&am…

CALL SYMPUT与CALL SYMPUTX区别

call symput 在data步中将值塞入宏变量http://www2.sas.com/proceedings/sugi29/052-29.pdf [SAS] CALL SYMPUT与CALL SYMPUTX CALL SYMPUT的功能是可以在DATA step内将值塞到一个macro变量里面。如果这个macro变量已经存在,那这个call就会更新该macro变量的值。 CA…

Linux基本结构

一个完整地Linux操作系统由4部分组成,即内核(Kernel)、外壳(Shell)、实用程序(Utilities)和应用程序(Applications)。 (1)内核是Linux的心脏&…

jmeter使用_jmeter工具的使用

1.本地下载到官网,5.3版本的对应的是jdk8版本,就用这个了2.解压进入bin目录,找到jmeter.bat启动它,会弹出两个窗口,一个是启动窗口,使用jmeter不可以关了它,另一个是jmeter的工作界面进入界面默…

UliPad 初体验----python 开发利器

学习python 有段时间,最近博客更新比较慢了,空闲时间在零零碎碎的学python ,难成文,也就没整理成博客。 学习python 最苦恼的就是没有趁手IDE ,之前学java 时 Eclipse 肯定是不二之选。eclipse pydev 也可以开发python…

Neo4j:找到两个纬度/经度之间的中点

在过去的两个周末中,我一直在处理一些运输数据,并且我想运行A *算法来查找两个车站之间的最快路线。 A *算法将一个EstimateEvaluator作为其参数之一,然后该评估器查看节点的经度/纬度,以确定一条路径是否值得遵循。 因此&#x…

猫狗大战

可行性背包 令dp[i][j]表示选i个人能否达到j这个状态,那么转移就和背包一样了,外层枚举选哪一个(K),2、3层枚举i,j,那么\[dp[i][j] | dp[i-1][j-val[k]];\] 转载于:https://www.cnblogs.com/bullshit/p/9902003.html

SAS的数组array介绍

SAS可以把一组同为数值型或同为字符型的变量合在一起,使用同一个名字称呼,用下标来区分。这与通常的程序设计语言中的数组略有区别,通常的程序设计语言中数组元素没有对应的变量名,而SAS数组每个元素都有自己的变量名。 一、数值型…

python while循环if_详解python基础之while循环及if判断

wlile循环while True表示永远为真,不管是什么条件都会向下执行,下面是写的一个例子。#!/usr/bin/env pythonage 24                            #给age赋一个值while True:                       …

关于页面的多种自适应布局——两列布局

我们在切页面的时候打交道最多的就是关于布局排版的技巧&#xff0c;我这里总结了一些平时做页面时用的到各种布局技巧&#xff0c;作为笔记便于日后随时查询。 1、简单结构1&#xff0c;列表在前&#xff0c;内容在后 1 <style type"text/css">2 .layout{back…

很全的sas基础知识

5.1 SAS表达式简介   &#xff11;&#xff0e;SAS常数表达式   (1)数值常数 如: 1.23、 -5、 0.5E-10。   (2)字符常数 如: name1TOME、 name2MARY、name3JOHN。   (3)日期(d)、时间(t)、日时(dt)常数 如: d101JAN80d、t19:25:19t、   dt118JAN80:9:27:05dt。  …

kitti数据集_KITTI数据集激光雷达坐标系下的里程计真值

由KITTI数据集Odometry模块的devkit_odometrydevkitreadme.txt所述&#xff0c;KITII数据集提供里程计的真值是在左相机表坐标系下的&#xff0c;并没有提供激光雷达坐标系下的真值。因此&#xff0c;求得激光雷达坐标系下的真值&#xff0c;对我们使用KITTI数据集进行点云处理…

python中文处理

一、使用中文字符 在python源码中如果使用了中文字符&#xff0c;运行时会有错误&#xff0c;解决的办法是在源码的开头部分加入字符编码的声明&#xff0c;下面是一个例子&#xff1a;#!/usr/bin/env python# -*- coding: cp936 -*-Python Tutorial中指出&#xff0c;python的…

信号量使用例子_用信号量锁定:一个例子

信号量使用例子并发是带来有趣挑战的一个方面。 如果处理不当&#xff0c;会带来种族问题&#xff0c;这会使人们感到困惑&#xff0c;因为这些问题有时会突然出现&#xff0c;并且有时会正常工作。 当处理访问公共资源的并发线程时&#xff0c;Java语言提供了许多处理竞争条件…

.net Reactor之exe、dll文件混淆

.net Reactor之exe、dll文件混淆 .net Reactor的主要功能&#xff1a; 1.是对dll文件、exe文件进行反编译混淆 2.对dll进行内部加锁&#xff0c;限制其使用的固定机器、固定时间、部署次数 2.创建证书文件&#xff0c;用证书管理其限制的机器、时间、部署次数 页面&#xff1a;…

简述SAS逻辑库的概念及建立方法。什么是临时库和永久库?

libname student e:\mysas;SAS中利用libname命令建立逻辑库&#xff0c;虽然之后建立的与其关联的永久数据集还保存在该逻辑库所指的目录中&#xff0c;但重启SAS后该库却没有显示于库目录中。 例如e:\mysas目录已存在&#xff0c;程序data student.aaa;……重启SAS后虽然数据集…

35 岁 学python 必要_程序员:Python学不学?完全没必要纠结

随着云计算、大数据、人工智能的大量应用&#xff0c;Python这毛头小子&#xff0c;成了当红炸子鸡&#xff0c;香飘四溢&#xff0c;撒播到互联网的每个角落里。1几家欢喜几家愁&#xff0c;欢喜的人&#xff0c;早就用上了&#xff0c;国外的Twitter、Google、Yahoo&#xff…

了解连接池

1.简介 连接池是一种通过在池中打开和管理N个数据库连接来提高应用程序性能的技术。 该应用程序只是请求连接&#xff0c;使用它&#xff0c;然后将其放回池中。 当应用程序需要连接时&#xff0c;就绪连接将保持可用状态&#xff0c;以供池中使用。 池管理连接生命周期&#x…