Excel Avanzado

Macros, Vba en Excel y muchos ejemplos de nuestro Curso de Excel Avanzado

Excel Avanzado
Logo Excel Avanzado

Evitar parpadeo en Excel (VBA)

| 1 comentario

Al momento de ejecutar una macro, el sistema muestra un resultado al usuario por cada ejecución realizada, esto en reiteradas ocasiones representa un inconveniente, ya que, en el caso de archivos muy pesados con bases de datos extensas, se puede extender el tiempo de la macro a varios minutos, quitándole el sentido de optimización de operaciones y simplificación a la herramienta macros.

 

Para evitar el parpadeo al momento de ejecutar una macro, se debe configurar las siguientes funciones 

 

Application.ScreenUpdating = False

Evita que la pantalla realice cada operación de las fórmulas de la macro, de modo que no se ejecute hasta que sea especificado.

 

 

Application.calculation = xlCalculationManual

Cada vez que se analiza una celda, Excel analiza todas las celdas que existen, por lo que colocarlo en manual evitará que se ejecuten cálculos innecesarios.

 

 

 Application.EnableEvents = False

Eventos de pantalla ejecutados por macros en la hoja y libro son desactivados.

 

 ActiveSheet.DisplayPageBreaks = False

Saltos de página, que por lo general se producen al compatibilizar diferentes versiones de Excel.

La ejecución de las fórmulas se vería de la siguiente manera:

 

Application.ScreenUpdating = False

Application.Calculation = xlCalculationManual

Application.EnableEvents = False

ActiveSheet.DisplayPageBreaks = False

Evitar Parpadeo Excel VBA 01, Evitar parpadeo en Excel (VBA) 

Para que la macro pueda ejecutarse adecuadamente, es necesario que al final de los enunciados, vuelvan a activarse, de tal manera que se pueda obtener un resultado.

El final del enunciado debe contener la siguiente fórmula:

 

Application.ScreenUpdating = True

Application.Calculation = xlCalculationAutomatic

Application.EnableEvents = True

ActiveSheet.DisplayPageBreaks = True

Evitar Parpadeo Excel VBA 02, Evitar parpadeo en Excel (VBA)

La mayoría de estos códigos tienen aplicaciones con mayor relevancia cuando se usan archivos cuyas macros pueden tardar un tiempo considerable como un mecanismo de optimización. Si la macro a ejecutarse tiene un enunciado más simple, herramientas como Application.EnableEvents no tendrán un impacto tan notorio como las otras funciones.

 

A continuación, se presentan ejemplos aplicando la herramienta en una macro.

 

Elaborado por: Juan Carlos Correa

 

Un comentario

  1. Hola Juan Carlos. Hace tiempo que aplico los tres primeros consejos, sin embargo, a pesar de desactivar el ScreenUbdating, al final siempre hace un "repintado" de las imágenes (shapes) que es muy molesto aunque sólo lo haga una única vez. Sabes por qué se produce este repintado de imágenes? Es como si al recalcular el espacio ocupado por las celdas, tuviera necesidad de volver a pintar las imágenes... Me gustaría saber si hay forma de evitarlo, porque el ScreenUbdating = False, por sí solo no lo evita.
    Gracia. Un saludo.

Deja un comentario

Los campos requeridos estan marcados con *.