SAS Programming

DATA Step, Macro, Functions and more
BookmarkSubscribeRSS Feed
☑ This topic is solved. Need further help from the community? Please sign in and ask a new question.
hhchenfx
Rhodochrosite | Level 12

Hi Everyone,

I have SAS9.4 (I think it is Base) and I would like to import an open file of either xlsx, csv or txt or any format that allow me to do so.

Can you please help?

Thanks,

HHC

 

 

1 ACCEPTED SOLUTION

Accepted Solutions
Tom
Super User Tom
Super User

@hhchenfx wrote:

Hi Everyone,

I have SAS9.4 (I think it is Base) and I would like to import an open file of either xlsx, csv or txt or any format that allow me to do so.

Can you please help?

Thanks,

HHC

 

 


No idea what "open file" means here so I will ignore that.  If is important then explain what it means.

 

Assuming you mean you want to get the contents of the Excel file into SAS dataset(s) what you can do depends on whether or not you have ACCESS to PC FILES licensed.  That includes the drivers to read Excel files directly.

 

So if you have an XLSX file you can treat it as it was a SAS library by using a LIBNAME statement with the XLSX engine.

So this code will copy all of the sheets in the XLSX file name din the LIBNAME statement into datasets in the WORK library.

libname myfile xlsx 'filename.xlsx';
proc copy inlib=myfile out=work;
run;

If you do not have SAS Access to PC FILES then the best thing to do is save the individual sheets in the Excel file into individual CSV files.  Make sure that none of the cells have embedded line breaks as that can cause creation of file SAS cannot read .

 

You can read a CSV file directly with a data step using code like this:

data want;
  infile 'myfile.csv' dsd truncover firstobs=2;
  length var1 8 var2 $10 datevar 8 ..... lastvar $50 ;
  informat datevar date9.;
  format datevar date9.;
  input var1 -- lastvar;
run;

If you want to let SAS GUESS what variables to create you can use PROC IMPORT.

proc import file='myfile.csv' dbms=csv out=want replace;
  guessingrows=max;
run;

But be prepared for it doing stupid things.

 

View solution in original post

3 REPLIES 3
Tom
Super User Tom
Super User

@hhchenfx wrote:

Hi Everyone,

I have SAS9.4 (I think it is Base) and I would like to import an open file of either xlsx, csv or txt or any format that allow me to do so.

Can you please help?

Thanks,

HHC

 

 


No idea what "open file" means here so I will ignore that.  If is important then explain what it means.

 

Assuming you mean you want to get the contents of the Excel file into SAS dataset(s) what you can do depends on whether or not you have ACCESS to PC FILES licensed.  That includes the drivers to read Excel files directly.

 

So if you have an XLSX file you can treat it as it was a SAS library by using a LIBNAME statement with the XLSX engine.

So this code will copy all of the sheets in the XLSX file name din the LIBNAME statement into datasets in the WORK library.

libname myfile xlsx 'filename.xlsx';
proc copy inlib=myfile out=work;
run;

If you do not have SAS Access to PC FILES then the best thing to do is save the individual sheets in the Excel file into individual CSV files.  Make sure that none of the cells have embedded line breaks as that can cause creation of file SAS cannot read .

 

You can read a CSV file directly with a data step using code like this:

data want;
  infile 'myfile.csv' dsd truncover firstobs=2;
  length var1 8 var2 $10 datevar 8 ..... lastvar $50 ;
  informat datevar date9.;
  format datevar date9.;
  input var1 -- lastvar;
run;

If you want to let SAS GUESS what variables to create you can use PROC IMPORT.

proc import file='myfile.csv' dbms=csv out=want replace;
  guessingrows=max;
run;

But be prepared for it doing stupid things.

 

SASKiwi
PROC Star

If an Excel workbook is already open, SAS will not be able to read it at all as Excel locks the file for editing. If you have a CSV file open in Excel I think you would have the same problem. Why do you want to read such a file while it is open?

ballardw
Super User

Adding to @SASKiwi's comment. Most programs that have the ability to edit values will lock the file so the edits done there are preserved. So if "open" means "in use by program X" then you need to specify which program that actually may be and why is it required to edit while open in another program. Those that don't edit files may not show any attempt to modify the contents by another program even if not locked. Plus may require a manual "refresh" to show any changes if the program can show them.

sas-innovate-wordmark-2025-midnight.png

Register Today!

Join us for SAS Innovate 2025, our biggest and most exciting global event of the year, in Orlando, FL, from May 6-9. Sign up by March 14 for just $795.


Register now!

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
  • 3 replies
  • 2351 views
  • 0 likes
  • 4 in conversation