Macro SAS. Variables de un dataset en una macro variable

6 Sep

Hoy os presento una macro de SAS que nos permite recoger en una macro variable las variables de un conjunto de datos SAS. Tiene como particularidad que nos sirve para seleccionar aquellas variables que tienen un determinado patrón, del tipo consumo2010, consumo2011,… Es un código un poco más complejo de lo habitual pero tiene aspectos interesantes:

options mlogic mprint;
%macro lista_variables (ds= , nombre_mv= , patron=);
*ES NECESARIO QUE LA MACROV FINAL SEA GLOBAL;
%global &nombre_mv.;
*PUEDE SER QUE LA LIBRERIA SEA WORK O PERMANENTE;
	data _null_;
	length lib tab $255.;
	if index("&ds.",".")=0 then lib="WORK";
	else lib=scan("&ds.",1,".") ; put lib=;
	call symput('libreria',lib);
	tab=scan("&ds.",2,".") ;
	call symput('tabla',tab);
	run;
*BUSCAMOS EN DICTIONARY DE SAS;
	proc sql noprint;
	select compress(name) into:&nombre_mv. separated by " "
	from sashelp.vcolumn
where libname=upcase("&libreria.") and memname=upcase("&tabla.") and
/*PODEMOS APLICAR UN PATRON*/
	upcase(name) like '%'||"%upcase(&patron.)"||'%';
	quit;
%mend;

El elemento principal de esta macro es una consulta a una de las tablas DICTIONARY de SAS. O mejor dicho, a una de las vistas que tenemos en SASHELP. Siempre he prefererido consultar las vistas de SASHELP. La vista consultada es VCOLUMN de donde extraemos la columna NAME y como condicionantes pasamos la librería en LIBNAME y el nombre de la tabla de la que deseamos obtener las variables en MEMNAME. Como particularidad podemos aplicar patrones.

Ejemplos de uso:

data importes sasuser.importes;
drop i j;
array importe(30) ;
do i=1 to 20000;
do j=1 to 30;
importe(j)=ranuni(8)*1000;
end;
grupo=ranpoi(4,5);
output;
end;
run;
*;
%lista_variables(ds=sasuser.importes , nombre_mv=lista_var1 , patron=);
%lista_variables(ds=importes , nombre_mv=lista_var2 , patron=importe);
*;
%put _user_;

Creo que esta macro es muy práctica y puede automatizaros mucho código. Saludos.
 

 

3 respuestas a «Macro SAS. Variables de un dataset en una macro variable»

  1. Buenas tardes,
    He encontrado esta línea de código dentro de una macro SAS y no se muy bien para que se está utilizando. ¿podéis ayudarme? ¿Para que sirve el parámetro DEBUG?

    %if &_DEBUG %then %put DEBUG: txtFields=&txtFields## ;

    Muchas gracias.
    Un saludo

  2. Hola¿ como puedo generar una macro para traer cifras diarias si solo cuento con una tabla con informacion mensual?? Esta mensual tambien entre sus campod trae fecha del dia

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *