Truco SAS. Crear ficheros Excel sin PROC EXPORT (II)

Con anterioridad hemos visto el manejo del ODS y como nos sirve para generar archivos HTML que podemos usar con Excel sin necesidad de emplear el PROC EXPORT. Pero el lenguaje SAS empleado era complicado y requería muchas líneas de código. Pues esto podemos evitarlo si creamos nuestra propia macro para exportar nuestras tablas SAS a tablas Excel.

“Simplemente” hemos de parametrizar el código que vimos en la primera parte del truco SAS. Pero realizaremos diversas modificaciones para que nuestro código sea más práctico:

%macro excel(ubicacion,dataset);option missing=""; 

title; 

/*ELIMINAMOS LA LIBRERIA SAS DEL NOMBRE*/ 

 %let aux1=%scan("&dataset.",2,"."); 

/*LAS VARIABLES NUMERICAS IRAN CON FORMATO EUROPEO*/ 

 proc contents data=&dataset. 

 			  out=_temporal_ (where=(type=1) keep=name type) noprint ; 

 run; 

/*CREAMOS UNA INSTRUCCION PARA DAR EL FORMATO EUROPEO*/ 

 proc sql noprint; 

 	select "format "||compress(name)||" commax12.6" into:_instruccion separated by "; " 

 	from _temporal_; 

 quit; 

proc delete data=_temporal_; run; 

/*EMPLEAMOS EL PROC PRINT JUNTO CON ODS*/ 

 filename _temp_ "&ubicacion.\&aux1..xls"; 

title ; 

 ods noresults; 

 ods listing close; 

 ods html file=_temp_ rs=none style=minimal; 

 	proc print data=&dataset. noobs; 

 	&_instruccion.; 

 	run; 

 ods html close; 

 ods results; 

 ods listing; 

option missing="."; 

%mend excel;

Con esta macro ya disponemos de una función que nos exporta nuestras tablas SAS a Excel. Por ejemplo:

data uno;
 do i=1 to 100;
  j=ranpoi(23,3);
  k=ranpoi(123,3);
  l=ranpoi(2,3);
  m=ranpoi(3,3);
  n=l/j;
  uno="hola";
  y=ranuni(89)*100;
 output;
 end;
run;
%excel(C:\,work.uno);

Interesante macro la que os planteo, puede sernos de gran utilidad a la hora de realizar validaciones de ficheros, tabular información, análisis exploratorios,… La interactuación entre SAS y Office nos facilitará nuestro trabajo.

Si tenéis más dudas o sugerencias… rvaquerizo@analisisydecision.es

17 comentarios en “Truco SAS. Crear ficheros Excel sin PROC EXPORT (II)

  1. Como puedo generar una frecuencia de valores perdidos para cada tabla de una librería ya creada, además reemplazar los missing en 0 cuando la variable es numérica y ñ cuando la variable es de carácter

  2. Hola.
    Necesitaría saber cómo puedo hacer para que cada categoría (de productos, por ejemplo) que tengo en mi fichero SAS, se exporte a UNA HOJA DIFERENTE de un mismo fichero Excel.
    Gracias

  3. Hola Victor, con ánimo de ayudar me he mirado la macro, la macro es correcta solo que Raul habría escrito este código en algun editor que a la hora de pegarlo se desvirtuó el “&”, es decir, todo lo que diga “&” significa realmente “&” (el &amp significa el ‘ampersand’, y NO es que Raul se olvidara de definir la macro variable ‘amp’).

    El código correcto sería:

    %macro excel(ubicacion,dataset);
    option missing=””;
    title;
    /*ELIMINAMOS LA LIBRERIA SAS DEL NOMBRE*/
    %let aux1=%scan(“&dataset.”,2,”.”);
    /*LAS VARIABLES NUMERICAS IRAN CON FORMATO EUROPEO*/
    proc contents data=&dataset.
    out=_temporal_ (where=(type=1) keep=name type) noprint ;
    run;
    /*CREAMOS UNA INSTRUCCION PARA DAR EL FORMATO EUROPEO*/
    proc sql noprint;
    select “format “||compress(name)||” commax12.6″ into:_instruccion separated by “;”
    from _temporal_;
    quit;
    proc delete data=_temporal_; run;
    /*EMPLEAMOS EL PROC PRINT JUNTO CON ODS*/
    filename _temp_ “&ubicacion.\&aux1..xls”;
    title ;
    ods noresults;
    ods listing close;
    ods html file=_temp_ rs=none style=minimal;
    proc print data=&dataset. noobs;
    &_instruccion.;
    run;
    ods html close;
    ods results;
    ods listing;
    option missing=”.”;
    %mend excel;

    %excel(C:\,work.uno);

    Un saludo,
    Dani Fernandez

  4. Travesuras de los editores:
    cuando dije “es decir, todo lo que diga “&” significa realmente “&” ” realmente el primer “&” significaba otra cosa que separo ahora por ‘/’:
    Quise decir:
    todo lo que diga ‘&/a/m/p/;’ significa realmente ‘&’.

    Esto es como explicar a un chino como escribir la ‘ñ’ de España escribiendo en un teclado ruso, que complicado!!!!

    jaja!

  5. Hola.
    Me gustaría, con código, poder importar datos desde un fichero Excel ubicado en una determinada uinidad de red. Estos datos están en una fila y columna determinada, y el encabezado no coincide con el nombre de las variables.

    Un saludo,
    Noemí

  6. Noemi lo más fácil es con una sentencia libname, suponiendo que a los datos en Excel le hayas puesto un nombre.

    libname libro ‘c:\datos.xls’ header=yes;

    data sasuser.borrar;
    set libro.rango;
    run;

    libname libro clear;

    En el código anterior se crea una librería llamada libro, esto hace que SAS considere el libro de Excel como si fuera una base de datos y cada una de las hojas como si fuera una tabla.
    rango es el nombre que yo le he puesto al rango de Excel que contiene los datos. Se crea una conjunto de datos en la librería sasuser y por último se desasigna la librería. En lo que respecta a los nombres de las variables SAS tomará los encabezados como nombre de las variables, haciendo los cambios necesarios para que se adapten a la sintaxis de nombres de variables de SAS. Pero una vez en SAS les puedes cambiar fácilmente los nombres por código.

    Espero que te sirva de ayuda. Saludos.

  7. Hola nuevamenete, como realizar una exportacion sin cabecera, es decir, utilizando el proc export existe alguna funcion que pueda utilizar para exportar sin los campos de la tabla?
    muchas gracias y un saludo

  8. Hola!
    Quiero exportar los datos de una tabla SAS a un Excel ya existente, en una pestaña concreta y en un lugar concreto de la pestaña. He probado creando referencias en Excel, y consigo que se me exporten los datos donde quiero, pero me borra el resto de la información que existe en la pestaña.
    ¿Algún código que me pueda servir de guía?

    Gracias!!

  9. Hola!
    Estamos intentando establecer una conexion desde excel a una tabla sas, pero no veo más que las librerias por defecto.
    ¿Como puedo hacer un libname en excel para que me deje elegir una tabla sas de esa libreria?
    gracias!

Deja un comentario

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