380 likes | 571 Views
SAS Options – Versatile Players in the Game of SAS. Denise Poll, SAS Institute Inc. Back in the “Day”. Today ---1500+ SAS System Options. What kinda “stuff” gets customized? Appearance of SAS output – PDF* options Handling of files – ENGINE=V9 Performance related – SORTSIZE=
E N D
SAS Options – Versatile Players in the Game of SAS Denise Poll, SAS Institute Inc.
Today ---1500+ SAS System Options What kinda “stuff” gets customized? • Appearance of SAS output – PDF* options • Handling of files – ENGINE=V9 • Performance related – SORTSIZE= • Security – PDFSECURITY= • Macro - MACRO
Game Plan • Basics • Interfaces • Tricks of the game • Acknowledgements and Questions
Basics of Syntax • Syntactically speaking --- Name and Value combination • Option METAPORT = 8561 ; /* Numeric */ • Option NOFMTERR; /* Boolean */ • Option CMPLIB = sasuser.funcs; /* Character */
Comparisons - System Options • System options – Remain in effect for all DATA and PROC steps unless re-specified • Specify using: • Options statement • Options DATASTMTCHK = ALLKEYWORDS; • Command line and configuration files • -DATASTMTCHK ALLKEYWORDS • Options Window
Comparisons - Data Set • Data set options – apply to the processing of the SAS data set with which they appear. Some data set options are also SAS System options. • Specify using • Data new ; /* Usage of FIRSTOBS overrules any previous setting */ set study ( FIRSTOBS = 5);
Comparisons Statement • Statement options – control the action of the statement in which they appear • Specify using • Proc Print data=study (FIRSTOBS = 20);
Forest For The Trees • If there are over 1500+ SAS System options how do I find the one that I need? • Documentation is always helpful • Proc Options LISTGROUPS; Proc Options;
Logical Groups Proc Options Group=(SORT PERFORMANCE) ; Group=SORT ….. SORTSIZE=0 Size parameter for sort Group=PERFORMANCE …… BUFNO=1 Number of buffers for each SAS data set
SAS System Options Interfaces • GETOPTION function • Proc Options • Command line • Configuration files – Verbose and restricted option files • Options statement • Options window • Procs Optsave and Optload • DMOPTSAVE and DMOPTLOAD • SQL usage
Getoption Function Keywords “Good Golly Miss Molly” • Subset of Return Value Options • DEFAULTVALUE - returns the default option value • STARTUPVALUE - returns value from SAS startup • HOWSET – returns a character string indicating setting interface • Subset of Return Value Formatting Options • EXPAND - WIN and UNIX, expand Environment Variables • KEYWORD - Option Name = Value • LOGNUMBERFORMAT – Numeric option value with “,”s
GETOPTION Function – Programmatic Use! Sas –orientation portrait Options Orientation = LANDSCAPE ; %let setopt = %sysfunc(GETOPTION (Orientation, KEYWORD, STARTUPVALUE)); Options &setopt; /* Orientation=PORTRAIT */
A True Classic - Proc Options • OPTION and GROUP • LOGNUMERFORMAT • LISTGROUPS - displays options in each group • DEFINE • VALUE • INSERT, APPEND, LISTINSERTANDAPPEND • EXPAND • RESTRICT – are restricted • LISTRESTRICT – can restrict
Proc Options - Display Option Values • Proc Options Option=(OBS ORIENTATION) >1 specified LOGNUMBERFORMAT; OBS=9,223,372,036,854,775,807 Number of the last observation to process ORIENTATION=PORTRAIT Orientation to use when printing
Again -- Logical Groups Proc Options Group=(SORT PERFORMANCE) ; Group=SORT ….. SORTSIZE=0 Size parameter for sort Group=PERFORMANCE …… BUFNO=1 Number of buffers for each SAS data set
Option Properties • Proc Options Option=AUTOEXEC DEFINE ; Group= ENVFILES Group Description: SAS library and file location information Type: The option value is of type CHARACTER Maximum Number of Characters: 1024
More Information – Option DEFINE When Can Set: Environment Startup or Session Startup only Casing: The option value is retained with original casing Quotes: If present during "set", start and end quotes are removed Restricted: Your Site Administrator cannot restrict modification of this option Optsave: Proc Optsave or command Dmoptsave will not save this option
Tattle Tail Feature – Value Keyword The GETOPTION function has the HOWSET keyword Proc Options uses the “VALUE” keyword to identify what interfaces set the option value • Some interfaces are: • command line, Config file(s), Options statement….. • Options that can “add to” an option value • INSERT= and APPEND= Options
Proc Options Simple Usage – Value Keyword Proc Options option=sasautos VALUE ; run; Option Value Information For SAS Option SASAUTOS Value: ( "!sasroot\.... " "!sasroot\....\testauto“ ) How option value set: Config File Config file name: C:\SASv9\tmp\SASv9-1068.cfg << Version 9.3
INSERT and APPEND SAS Options • Some options support adding to the option value using INSERT and APPEND Example: Config File contains: -Append AUTOEXEC myconfigAUTO.sas Command line contains: -Append AUTOEXEC mycmdAUTO.sas Result: myconfigAuto.sas mycmdAUTO.sas
Insert and Append Options Proc Options LISTINSERTAPPEND; run; • Core options: INSERT and APPEND • AUTOEXEC Identifies AUTOEXEC… • CMPLIB Identify previously… • FMTSEARCH List of catalogs to… • MAPS Location of maps for… • SASAUTOS Search list for autocall… • SASHELP Location of the…
Proc Options – Value Keyword Proc Options Option=AUTOEXEC VALUE; Value ('!mydir\twoAuto.sas‘ '!mydir\twoAuto.sas‘) How option value set: Config File Value Inserted: '!mydir\twoAuto.sas' Config file name: U:\config2.cfg How option value set: Config File Value Inserted: '!mydir\oneAuto.sas' Config file name: C:\MySAS\ConfigDNT.cfg
Expand Environment Variables Expansion of environment variables in the physical name …same support that we saw earlier with the GETOPTION function Proc Options Option=SASHELP EXPAND ; Without Expand: myval = ("!sasroot\sas… With Expand: myval = ("C:\SASv9\sas….
Restricted Options • Proc Options LISTRESTRICT; /* CAN restrict */ • Proc Options RESTRICT; /* IS restricted */ 3 Configuration File 2SAS Command 1 Site Restricted Configuration File
Restricted Options Output Proc Options LISTRESTRICT; run; Your Site Administrator can restrict the ability to modify the following Portable Options: APPLETLOC Location of Java applets ... BUFNO Number of buffers for each SAS data set BUFSIZE Size of buffer for page of SAS data set ... CGOPTIMIZE Control code generation optimization ... COMAMID Specifies the communication access….
Saving and Loading Option Values • Procedures OptSave and OptLoad • What options cannot be saved? • Session startup options • Password options Proc Optsave Data=WORK.saveopts; NOTE: The data set …. has 262 observations and 2 variables. Proc Optload Data=WORK.saveopts;
Verbose Option – Old Style sas -verbose ==== Processed Configuration File(s) ==== C:\SASv9\tmp\SASv9-5776.cfg ==== Environment Variable Options ==== <none> Option Value ====== ===== MAPS "!sasroot\sasgen\....en\maps" SASAUTOS "!sasroot\sas\.....\auto\en"
Verbose Option – New for 9.3 sas -verbose --------------------------------------------------------------- Options specified on the command line: --------------------------------------------------------------- SASHOST = C:\....dll DMS….. --------------------------------------------------------------- Options specified in the config file C:\SASv9\… --------------------------------------------------------------- SASAUTOS = ( !sasroot\....) SASHELP= ( !sasroot\....)
Acknowledge and Question Bravo to my fellow portable and host developers, testers and writers who collaborate to bring SAS system options to customers. Questions?