Si tiene una gran cantidad de libros de trabajo que desea procesar mediante el uso de macros, puede tener la tentación de colocar la macro de procesamiento dentro de cada libro de trabajo (como una macro Auto_Open), y luego escribir algún tipo de rutina para cargar cada libro de trabajo, a su vez, y guárdelo.

Si bien esto puede sonar bien en teoría, no funcionará en la práctica. ¿Por qué?

Porque cuando abre un libro bajo control de macros, la macro Auto_Open en el libro que se abre no se ejecutará automáticamente. Hay tres formas de solucionar este problema.

La primera es rehacer su macro para que no dependa de las macros Auto_Open en cada libro de trabajo. Si la macro Auto_Open en cada libro de trabajo es la misma, entonces ¿por qué no simplemente mover el código a un procedimiento separado en el libro de control? Por ejemplo, digamos que estaba usando código que siguió este proceso:

Sub MyMacro()

Dim J As Integer     Dim sTarget As String

Application.ScreenUpdating = False     For J = 1 To 999         sTarget = "Book" & Format(J, "000") & ".xls"

Workbooks.Open sTarget         'Auto_Open runs here         Workbooks(sTarget).Save     Next J     Application.ScreenUpdating = True End Sub

Esto no funcionará, por las razones ya explicadas. Una solución es simplemente mover el código común Auto_Open a otro procedimiento y luego llamarlo después de abrir el libro de trabajo, como se muestra aquí:

Sub MyMacro()

Dim J As Integer     Dim sTarget As String

Application.ScreenUpdating = False     For J = 1 To 999         sTarget = "Book" & Format(J, "000") & ".xls"

Workbooks.Open sTarget         Workbooks(sTarget).Activate         DoCommonCode         Workbooks(sTarget).Save     Next J     Application.ScreenUpdating = True End Sub
Sub DoCommonCode()

'Common code goes here End Sub

Este enfoque funciona bien, siempre que la rutina sea la misma que se ejecutará en todos sus diferentes libros de trabajo. Si las rutinas son diferentes en cada libro de trabajo, puede forzar a VBA a ejecutar la macro Auto_Open. Esto se hace usando el método RunAutoMacros justo después de abrir los libros de trabajo:

Workbooks.Open sTarget ActiveWorkbook.RunAutoMacros xlAutoOpen

Dado este enfoque, podría crear fácilmente una macro que simplemente abriera cada libro de trabajo (para que se pudieran ejecutar las macros Auto_Open) y luego guardarlas. Tal macro aparecería como sigue:

Sub RunAutoOpenMacrosInBooks()

Dim J As Integer     Dim sTarget As String

Application.ScreenUpdating = False     For J = 1 To 999         sTarget = "Book" & Format(J, "000") & ".xls"

On Error Resume Next         Workbooks.Open sTarget         Windows(sTarget).Activate         With ActiveWorkbook             If .Name <> ThisWorkbook.Name Then                 .RunAutoMacros xlAutoOpen                 .Save                 .Close             End If         End With     Next i     Application.ScreenUpdating = True End Sub

Un tercer enfoque, e incluso mejor, es no depender de las macros Auto_Open en cada uno de sus libros de trabajo. En su lugar, confíe en el evento Workbook_open como una forma de ejecutar su macro. El evento Workbook_open se activa automáticamente, independientemente de si el libro se abre manualmente o en otra macro. El código que contiene el evento se ejecuta automáticamente, tal como cabría esperar de una macro Auto_Open.

_Nota: _

Si desea saber cómo usar las macros descritas en esta página (o en cualquier otra página de los sitios ExcelTips), he preparado una página especial que incluye información útil.

link: / excelribbon-ExcelTipsMacros [Haga clic aquí para abrir esa página especial en una nueva pestaña del navegador].

ExcelTips es su fuente de formación rentable en Microsoft Excel.

Este consejo (2278) se aplica a Microsoft Excel 97, 2000, 2002 y 2003. Puede encontrar una versión de este consejo para la interfaz de cinta de Excel (Excel 2007 y posterior) aquí:

link: / excelribbon-Running_a_Macro_in_a_Number_of_Workbooks [Ejecución de una macro en varios libros de trabajo].