There appears to be no ideal solution. The best I could devise requires the use of two part names, a non-trivial amount of extra code, a custom setup, and is potentially confusing to other programmers. The easiest configuration appears to be the default behavior: simply dumping all data sets in the Work
library and sifting through all of them.
For prosperity, here is the best solution I could devise to organize things.
- Understanding the Display Manager and Explorer Window
The Display Manager (DM) controls the various windows in the Enhanced Editor. This includes windows such as log
, results
, pgm
, output
and explorer
. It is the latter which is of principle interest here.
A user may configure windows per session using the menus. There exist, however, a set of commands which may be used to automatically configure the DM for each session. When used with the AUTOEXEC.sas
facility, this allows the user to 'permanently' configure the SAS editor to their preferences.
The default explorer
view for the Enhanced Editor is the "Contents of 'SAS Environment'".

When the explorer
window is selected, a tree hierarchy view can be toggled. There are several ways to do this. Here is one way:
- Select the
explorer
window
View > Show Tree

Having to do this every time SAS is opened becomes a pain. After we clean up the library tree, we will automate this.
- Remove any extraneous libraries
SAS loads a variety of libraries by default. These include WORK
, SASHELP
, and SASUSER
, as well as others that are part of non-base products. In my case, the MAPS
, MAPSGFK
, and MAPSSAS
libraries are also loaded (see above picture). As I never have used these (and likely never will), they only serve to clutter up my library directory. To remove these, one can edit their config file.
SAS implements a whole web of config files. On a Windows system, the likely relevant sasv9.cfg
file is located here:
C:\Program Files\SASHome\SASFoundation\9.4\nls\en
You will need admin rights to edit it. Disregarding the DO NOT EDIT BELOW THIS LINE
warning, comment out the the following using PL/I style comments.
Un-commented:
-MAPS !SASROOT\maps
-MAPSGFK !SASROOT\mapsgfk
-MAPSSAS !SASROOT\maps
Commented:
/* -MAPS !SASROOT\maps*/
/* -MAPSGFK !SASROOT\mapsgfk*/
/* -MAPSSAS !SASROOT\maps*/
Now when SAS opens, the MAPS
, MAPSGFK
, and MAPSSAS
library will not be automatically loaded. Unfortunately, there does not seem to be a way to disable the loading of the SASUSER
and SASHELP
libraries. If someone knows how, please let me know!
- Configure the Explorer Window
The explorer
window can be 'configured' using the DM statement and the AUTOEXEC.sas
facility.
Navigate to the directory containing SAS.EXE
. On a default Windows installation, it is located here:
C:\Program Files\SASHome\SASFoundation\9.4
Create a SAS program named AUTOEXEC.sas
containing the following code and place it in the directory which contains SAS.EXE
. This step requires admin privileges. I find it easiest to create the file in a non-privileged environment and simply copy the AUTOEXEC.sas
program into the directory.
Include this in the AUTOEXEC.sas
program:
dm 'dmsexp; tree; expand libraries; expand work;';
When SAS intializes, the AUTOEXEC.sas
code is executed before any user input is accepted. The above code does the following:
dmsexp - Brings the explorer
window into command focus.
tree - Toggles the tree hierarchy view.
expand libraries - Within the "Active Libraries" pane, drills down into Libraries.
expand work - Within the "Active Libraries" pane, drills down into the Work
library.
Each of these is a separate command and could be issued on separate lines. Instead of this, semi-colons are used to issue them in a single line.
Now when SAS is opened, the tree menu is available and the contents of the Work
library are viewed. The picture below is somewhat deceiving. The "SAS Environment" pane is not set to a convenient width as pictured. It must be manually adjusted. If anyone has a way to automate this, please let me know!

- Storing data sets in sub-folders
To ensure that data sets are deleted when the SAS session ends, sub-folders needs to be created within the temporary system folder where the Work
library points to.
The following structure can now be followed:
/*Determine location of Work directory*/
%let dirWORK = %sysfunc(pathname(Work));
/*Allow LIBNAME statement to create new directories*/
options dlcreatedir;
/*Create sub-folders within the temporary Work directory
and assign librefs*/
libname raw "&dirWORK./raw";
libname interm "&dirWORK./intermediate";
libname results "&dirWORK./results";
Now, all the raw data sets can be assigned to the raw
library. Within SAS, they will be logically separated from Work
. That is, if the data set foobar
is created in the raw
library, it can only be accessed via raw.foobar
. A statement such as data = foobar
or data = work.foobar
will not work. Yet because the raw
library is in fact a sub-folder of Work
, it will be deleted when the SAS session is ended.