SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 1247|回复: 4
打印 上一主题 下一主题

请教:如何读入多个文件夹下的所有指定文件?

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2008-4-2 16:57:31 | 只看该作者

请教:如何读入多个文件夹下的所有指定文件?

工作中需要将多个目录(总数不确定)内的ABC.TXT读入到一个数据集,请教应如何获取文件所在目录?
  我尝试用以下代码获取文件所在目录,但是x命令必须手工输入EXIT退出。请问,是否有方法可以运行DOS命令且不需要手工干预,或是别的方法实现该目标?

代码:
    x 'd:\test\abc.txt /s >directory.dir';
    data directory;
    infile 'directory.dir';
    input   xxxxxxxxx;
    run;
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2008-4-7 12:18:43 | 只看该作者

Re: 请教:如何读入多个文件夹下的所有指定文件?

你可以 environment variable stores all the paths

eg.
set DIR_PATH = D:\test\abc.txt;C:\temp\abc.txt;

Then,
After called up SAS, get back the environment variable DIR_PATH as macro variable

data _null_;
    path=sysget('DIR_PATH');
    call symput('FILE_PATH',path);
run;

Then marco variable &FILE_PATH stores all paths you needed.
You can just use function SCAN() to get every path delimited by ';'
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2008-4-7 17:50:38 | 只看该作者

Re: 请教:如何读入多个文件夹下的所有指定文件?

Add the statement below in your pgm.
options noxwait;
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2008-4-17 19:23:29 | 只看该作者

Re: 请教:如何读入多个文件夹下的所有指定文件?

hi

[code:3d1snsqx]filename f_list pipe "dir D:\matlabtestdata\test080413 /b";
data mylist;
infile f_list;
input file :$14.;
put file;
run;

proc print;
run;[/code:3d1snsqx]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
5#
 楼主| 发表于 2008-6-3 14:06:44 | 只看该作者

Re: 请教:如何读入多个文件夹下的所有指定文件?

options noxwait;
该选项可以替代手工输入EXIT退出.
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2026-2-4 18:13 , Processed in 0.068164 second(s), 19 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表