BookmarkSubscribeRSS Feed
dennis_oz
Quartz | Level 8

 

Requirement 1 -> read all multiple excel files as in multiple structures as character . 

  1. cannot convert it to csv

 

 

 

5 REPLIES 5
Kurt_Bremser
Super User

It is not possible in one pass. Any method (proc import or libname xlsx) will have its own idea about column attributes, so you will need to fix it in a follow-up step that converts all _numeric_ variables to character.

DavePrinsloo
Pyrite | Level 9

The handling of reading xlsx was improved a lot in SAS 9.4 when  xlsx engine was introduced.  Do you really still have 9.3?

 

 

 

ballardw
Super User

@dennis_oz wrote:

 

Requirement 1 -> read all multiple excel files as in multiple structures as character . 

  1. cannot convert it to csv

 

 

 


Convert to Tab delimited and use the approach would use with CSV only with TAB delimiter.

(I suspect you meant "can't convert to any text file format that would actually allow this with 9.3")

And where did the "cannot convert" restriction come from? If you have a lot of files of the same structure it is much easier to deal with the text formats such as CSV because you can use wildcards in file names to read multiple files with a singe data step. Which does insure that all the like variables have the same properties for length.

 

If you mean to force a Proc Import approach then there is no way you can control that length issue other than inserting a common row of values at the top of each file. Which is likely to be more work than you expect.

Vince_SAS
Rhodochrosite | Level 12

Maybe something like this will work for you:

 

options validmemname=extend;

libname xl excel 'C:\temp\numeric.xlsx';

data work.character;
set xl.'sheet1$'n(dbsastype=('a'='char(10)'
                             'b'='char(10)'
                             'c'='char(10)'
                             'd'='char(10)')
                  );
run;

 

The EXCEL engine is supported only on Windows, and the bitness of SAS must match the bitness of Windows.

 

Vince DelGobbo

SAS R&D

Patrick
Opal | Level 21

@dennis_oz wrote:

 

Requirement 1 -> read all multiple excel files as in multiple structures as character . 

  1. cannot convert it to csv

Except for the approach @Vince_SAS proposes - which I'm not sure is already available in SAS 9.3 - there is no direct way to read all source data into character variables only.

I believe if reading from an Excel source SAS will always attach a format to the created variables. If so then you could try if code as below does what you're after.

%macro convertAllVarsToChar(inds, outds=);
  %let inds=%upcase(&inds);
  %if &outds= %then %let outds=&inds;
  %local lib tbl;
  %let lib=%scan(WORK.&inds,-2,.);
  %let tbl=%scan(&inds,1,.);

  proc sql;
    create table want_meta as
    select *
    from dictionary.columns
    where libname="&lib" and memname="&tbl"
    order by varnum
    ;
  quit;

  filename codegen temp;
  data _null_;
  /*  file print;*/
    file codegen;
    set want_meta end=last;

    length nm_in nm_out $35;
    nm_in =cats("'",name,"'n");
    nm_out=cats("'_",substrn(name,1,31),"'n");

    if _n_=1 then
      do;
        put 
          "data &outds;" /
          @3 "set &inds;"
          ;
      end;

    if type='num' then
      do;
        if format='BEST.' then format='BEST16.';
        put @3 nm_out '= put(' nm_in ',' format ');';
      end;
    else
      put @3 nm_out '=' nm_in ';';
    put
      @3 'drop ' nm_in ';' /
      @3 'rename ' nm_out '=' nm_in ';' 
      ;
    if last then
      put 'run;';
  run;

  %include codegen / source2;
  filename codegen clear;
%mend;

proc import 
  datafile='~/test/test.xlsx'
  out=want
  dbms=xlsx
  replace
  ;
run;

title 'Before Conversion';
proc contents data=want;
run;

%convertAllVarsToChar(want);

title 'After Conversion';
proc contents data=want;
run;
proc print data=want;
run;

 

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 5 replies
  • 2349 views
  • 5 likes
  • 6 in conversation