1

我正在尝试使用以下代码列出文件夹中带有前缀的所有文件名,并使用文件名调用名为 CALCU 的函数:

  proc contents data=&libref.._all_ noprint out=contents; run;
  data _null_;
    set contents;
    by memname;
    if first.memname ;
    if upcase(memname) =: %upcase("&prefix");
    call execute(cats('%nrstr(%CALCU)(',memname,')'));
  run;

当我完全授权访问目录中的所有文件时,代码工作正常。但是现在我发现我实际上无法访问某些具有某些前缀的文件(幸运的是,我实际上并不需要那些我无权访问的文件)。

但是,SAS 只是不断抛出错误,例如

ERROR: User does not have appropriate authorization level for file
       TAQ_CT.CTM_20120222.DATA.

即使这不是我想要的文件。

我想知道如何跳过目录中的一些文件?

我试图删除除以下代码行之外的所有其他内容:

  proc contents data=&libref.._all_ noprint out=contents; run;

尽管如此,当我无法访问所有文件时,似乎我什至无法正确读取内容(SAS 只是不断抛出我无权访问的文件的错误)。

4

1 回答 1

1

我没有办法测试这个,但尝试SASHELP.VMEMBER而不是PROC CONTENTS

data _null_;
    set SASHELP.VMEMBER(where=(libname=upcase("&libref") and memtype = "DATA"));

    if upcase(memname) =: %upcase("&prefix");
    call execute(cats('%nrstr(%CALCU)(',memname,')'));
run;

这是一个列出目录中所有 SAS 文件的系统视图。这样,您只尝试访问您想要的那些。

于 2017-06-16T14:23:20.410 回答