Archivo de la etiqueta: automatizar código

Truco R. Eval, parse y paste para automatizar código

La función paste nos permite concatenar cadenas de texto con R:

paste("Dato",rep(1:10),sep="")

Parse recoge una expresión pero no la evalúa:

parse(text="sqrt(121)")

Y por último eval evalúa una expresión:

eval(parse(text="sqrt(121)"))

Interesantes funciones que nos pueden permitir automatizar códigos recursivos o códigos guardados como objetos en R. Imaginemos el siguiente ejemplo de R:

ejemplo1 <- data.frame(replicate (20,rpois(20,10)))
nom <- paste("dato",1:20,sep="")
names(ejemplo1) <- nom
summary(ejemplo1)

Hemos automatizado los 20 nombres de un data frame con datos aleatorios con una distribución de poissón de media 10 creado con la función replicate. Ahora imaginemos que deseamos transformar en factor sólo aquellos elementos del data frame con un sufijo par (datos2, datos4, …). Podemos crear una función o podemos crear ejecuciones de código R del siguiente modo:

ejecucion <- paste("ejemplo1$dato",seq(2,20,by=2),"<-as.factor(ejemplo1$dato",
seq(2,20,by=2),")",sep="")
ejecucion
[1] "ejemplo1$dato2<-as.factor(ejemplo1$dato2)"
[2] "ejemplo1$dato4<-as.factor(ejemplo1$dato4)"
[3] "ejemplo1$dato6<-as.factor(ejemplo1$dato6)"
[4] "ejemplo1$dato8<-as.factor(ejemplo1$dato8)"
[5] "ejemplo1$dato10<-as.factor(ejemplo1$dato10)"
[6] "ejemplo1$dato12<-as.factor(ejemplo1$dato12)"
[7] "ejemplo1$dato14<-as.factor(ejemplo1$dato14)"
[8] "ejemplo1$dato16<-as.factor(ejemplo1$dato16)"
[9] "ejemplo1$dato18<-as.factor(ejemplo1$dato18)"
[10] "ejemplo1$dato20<-as.factor(ejemplo1$dato20)"

Ahora tenemos que hacer que un objeto con instrucciones se ejecuten con parse y eval:

eval(parse(text=ejecucion))
summary(ejemplo1)

Hemos transformado en factores los elementos con sufijo par. Esto puede realizarse con sapply pero merece la pena que le echéis un vistazo a este proceso, lo ejecutéis y aprendáis una forma de automatizar código. En breve tendréis otro ejemplo de uso de esta metodología muy parecida a la que empleamos cuando programamos en otros lenguajes con menos futuro que R. Saludos.

Trucos SAS. Informes de valores missing

A continuación os planteo como truco SAS una duda que nos mandaba LILIANA. Ella necesitaba estudiar los valores perdidos de las tablas de una librería determinada. En este caso vamos a estudiar los missing de las variables numéricas de una librería, de forma análoga se puede hacer con las alfanuméricas. Como siempre vamos a trabajar con un ejemplo que parte de tablas generadas aleatoriamente. Comenzamos generando estas tablas: Seguir leyendo Trucos SAS. Informes de valores missing