BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
RavenWu
Calcite | Level 5

I have seen some questions related to this in this forum, but still not very clear yet, so I would like to post my quesion here.

 

I want to read in a 'sas7bdat' , here is my codes:

 

LIBNAME Website 'D:\Desktop';
DATA Website;
 INFILE 'Websites.sas7bdat';
RUN;

It seems that the LIBNAME statement is usually used as a method to read a data with this format, I point out the path for SAS, then read inthis data by a DATA step, 

 

The error appears:

ERROR: Physical file does not exist, C:\Windows\system32\Websites.sas7bdat.

I didn't point out the file to the C drive, so this error is weird. Could anybody tell me more about this?

1 ACCEPTED SOLUTION

Accepted Solutions
Tom
Super User Tom
Super User

SAS doesn't store datasets in memory like some other analytic tools. It reads the data from the disk when it needs to. This is why it does not have as many arbitrary limits on the size of dataset.

 

So if you want to use an existing data set with a procedure or data step then you just reference the dataset at the appropriate place. Hence the example PROC PRINT I posted before.  If you want to run another data step to create some derived variables from your existing data then you would use a SET statement in your data step to reference the existing dataset.

 

data new ;
   set 'websites.sas7bdat';
   if last_mod > '01JAN2016'd then status = 'RECENT';
   else status = 'STALE';
run;

View solution in original post

6 REPLIES 6
Tom
Super User Tom
Super User

You do not read a dataset like you would a text file. Instead you just reference it.

You can use the two level name approach like you started with. First create the library name (or LIBREF).  You can then reference the data using libref.memname syntax.

 

You did not provide the name of the dataset you want to read so let's just assume it is actually a file named 'websites.sas7bdat' that is in the directory 'D:\'.  So your syntax would be:

 

libname mylib 'D:\';
proc print data=mylib.websites;
run;

Now you can make it even easier by just using the quoted physical pathname of the file.  SAS will automatically create a library for you.

proc print data="D:\websites.sas7bdat";
run;

 

RavenWu
Calcite | Level 5

Thank you very much @Tom , one more question, maybe a stupid question. You said 'You do not read a dataset like you would a text file. Instead you just reference it', so is the DATA-INFILE procedure also just procedure of referencing data?

 

DATA Website;
INFILE 'Websites.sas7bdat';
RUN;

 

If I want to get this data into SAS, is there a way to do it? or say, for the  sas7bdat file, normally we don't need to get it into SAS, instead, just reference it?

 

 

 

 

Tom
Super User Tom
Super User

SAS doesn't store datasets in memory like some other analytic tools. It reads the data from the disk when it needs to. This is why it does not have as many arbitrary limits on the size of dataset.

 

So if you want to use an existing data set with a procedure or data step then you just reference the dataset at the appropriate place. Hence the example PROC PRINT I posted before.  If you want to run another data step to create some derived variables from your existing data then you would use a SET statement in your data step to reference the existing dataset.

 

data new ;
   set 'websites.sas7bdat';
   if last_mod > '01JAN2016'd then status = 'RECENT';
   else status = 'STALE';
run;
RavenWu
Calcite | Level 5
Thank you!
LinusH
Tourmaline | Level 20
The data is in SAS as soon as you submit the libname statement.
Therefore, any references to it should NOT contain the physical file name of the data set.

References to it in a data step is done vis the SET statement, not INFILE.

There's a free on line SAS programming training where these concepts should be taught.
Data never sleeps
RavenWu
Calcite | Level 5
OK, THANK YOU!!!

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