Chapter Contents |
Previous |
Next |
CALL SET |
Category: | Variable Control |
Syntax | |
Arguments | |
Details | |
Examples | |
See Also |
Syntax |
CALL SET(data-set-id); |
Details |
Using SET can significantly reduce the coding that is required for accessing variable values for modification or verification when you use functions to read or to manipulate a SAS file. After a CALL SET, whenever a read is performed from the SAS data set, the values of the corresponding macro or DATA step variables are set to the values of the matching SAS data set variables. If the variable lengths do not match, the values are truncated or padded according to need. If you do not use SET, then you must use the GETVARC and GETVARN functions to move values explicitly between data set variables and macro or DATA step variables.
As a general rule, use CALL SET immediately following OPEN if you want to link the data set and the macro and DATA step variables.
Examples |
This example uses the CALL SET routine:
%macro setvar; %let dsid=%sysfunc(open(sasuser.houses,i)); /* No leading ampersand with %SYSCALL */ %syscall set(dsid); %let rc=%sysfunc(fetchobs(&dsid,10)); %let rc=%sysfunc(close(&dsid)); %mend setvar; %global price style; %setvar %put _global_;
GLOBAL PRICE 127150 GLOBAL STYLE CONDO
data mydata; /* create variables for assignment */ /*by CALL SET */ length style $8 sqfeet bedrooms baths 8 street $16 price 8; drop rc dsid; dsid=open("sasuser.houses","i"); call set (dsid); do i=1 to 10; rc=fetchobs(dsid,i); output; end; run;
See Also |
Functions:
|
Chapter Contents |
Previous |
Next |
Top of Page |
Copyright 1999 by SAS Institute Inc., Cary, NC, USA. All rights reserved.