Referenciar hojas de cálculo (Worksheets)

Cuando desarrollamos códigos en VBA, en muchas ocasiones necesitamos referenciar distintas hojas (worksheets) de un mismo libro (workbook) o de un libro distinto al que contiene las macros para realizar operaciones entre ellas. A continuación te mostramos distintos métodos que podemos usar para hacer dichas referencias. Cada uno de estos métodos puede ser más o menos útil dependiendo de la naturaleza del desarrollo.

Referenciar hojas por su nombre visible

La referencia de las hojas por su nombre visible es muy usada, ya que a todos los que estamos acostumbrados al ambiente Excel nos resulta muy familiar. La debilidad de este método es que el nombre visible de la hoja debe permanecer inalterable para que no se genere un error en tu macro o código VBA.

Suponiendo que queremos referenciar una hoja para su activación, la secuencia de comandos para hacerlo es:

Sheets(“Nombre de pestaña”).Activate

Ejemplo:

Sheets(“Hoja 1”).Activate

Referenciar hojas por su índice o lugar en el libro

Este método aplica cuando se busca referenciar la hoja según el orden de la pestaña que ocupe en el libro de Excel. Así, la primera pestaña tendrá un índice de 1, la segunda un índice de 2 y así sucesivamente. Con este método podrás cambiar el nombre visible de la hoja sin ningún problema, pero el orden o índice de las pestaña u hoja referenciada debe ser siempre el mismo para que el código VBA haga lo que necesitamos.

Siguiendo el mismo ejemplo de activar una determinada hoja, la secuencia de comandos para hacerlo utilizando índices es:

Sheets(“Índice de  la pestaña”).Select

Ejemplo:

Sheets(3).Select

Nótese que en este caso utilizamos la opción .Select, en lugar de .Activate para activar la hoja, pero ambas opciones generan el efecto deseado.

Referenciar hojas por su nombre interno o nombre de código

El nombre visible de las pestañas en Excel no es necesariamente el mismo nombre interno o de código con el que Excel se refiere a las hojas  de trabajo. Para ver y modificar este nombre de código es necesario hacerlo desde el editor de VBA. Como ya te puedes imaginar, es más difícil que usuarios sin conocimientos de VBA tengan acceso a este nombre para modificaarlo, por lo que referencias las hojas de trabajo bajo este método ofrece mayor seguridad y estabilidad del código de nuestra macro, independientemente de si se modifica el nombre visible de la pestaña o su orden en el libro. Por esta razón es nuestra SmartCode Recomendation.

La secuencia de comandos para activar una hoja usando su nombre de código es:

Nombre Interno de la hoja.Activate

Ejemplo:

Hoja1.Activate

Quieres saber más? Contáctanos...

Selección de Rangos

La selección de Rangos o Select Range  es una actividad muy usada en la programación en VBA. Existen varios métodos muy similares entre sí para la selección de rangos de celdas, te presentaremos los más comunes.

Selección de rangos por referencias

En Excel estamos acostumbrados a referirnos a una celda según aparece por defecto en una hoja de cálculo, es decir, según la letra de la columna y el número de la fila. Si deseamos utilizar esta forma, debemos referirnos al rango con su identificación de columnas y filas tal y como aparecen en la hoja de cálculo separando con dos puntos “:” las celdas de inicio y fin del rango. Aunque no es obligatorio, es buena práctica hacer la referencia a la hoja donde se encuentra el rango que se desea seleccionar. La secuencia de comandos para hacerlo es:

Referencia a la hoja.Range(“Celda inicio rango:Celda fin rango”).Select

Ejemplo:

Sheets(“Hoja 2”).Range(“A2:B3”).Select

Selección de rangos en forma matricial

Aunque es similar a la selección de celdas, esta forma es más versátil porque te permitirá moverte entre filas o columnas fácilmente a través de Loops, por ello es nuestra SmartCode Recomendation. Te podrás referir a ella bajo la siguiente estructura:

Referencia a la hoja.Range(Celda inicio rango,Celda fin rango).Select

Donde la referencia a las celdas se debe hacer en forma matricial: Sheets(índice de hoja).Cells(Fila,Columna)

Ejemplo:

Sheets(2).Range(Sheets(3).Cells(2,1),Sheets(3).Cells(3,2)).Select

Quieres saber más? Contáctanos...

Seleccionar una celda de una hoja Excel

En VBA (Visual Basic for Applications), seleccionar celdas en Excel es una de las operaciones más comunes. Ya sea que quieras seleccionar una celda específica, un rango de celdas o moverte entre celdas en un bucle (loop), entender cómo referenciar celdas en VBA es fundamental. A continuación, te mostramos cómo hacerlo de manera eficiente y optimizada para tus macros en Excel.

1. Selección de celdas por referencia directa

La forma más básica de seleccionar una celda en VBA es referirse a su dirección directamente, como si estuvieras trabajando en Excel. Por ejemplo, si quieres seleccionar la celda "E2", usarías el siguiente código:

Range("E2").Select

Este método es ideal para selecciones simples, pero si necesitas manejar celdas dinámicas o realizar selecciones más complejas, te recomendamos utilizar métodos más avanzados.

2. Selección de celdas en forma matricial

Si necesitas seleccionar celdas de manera más flexible o realizar operaciones sobre múltiples celdas, puedes usar la forma matricial. Esto es especialmente útil cuando trabajas con bucles o estructuras más dinámicas. En este caso, puedes especificar la fila y la columna de la celda que deseas seleccionar.

Para hacer esto, puedes usar la función Cells en combinación con la referencia a la hoja de cálculo. Esto es útil cuando las filas y columnas son variables y no deseas hacer una referencia fija como en el ejemplo anterior.

Sheets("Nombre de la hoja").Cells(Fila, Columna).Select

Por ejemplo, si deseas seleccionar la celda en la fila 2 y columna 5 (que corresponde a la celda E2), el código sería:

Sheets("Hoja 1").Cells(2, 5).Select

Este enfoque es útil cuando trabajas con rangos variables o en casos en los que la celda de destino puede cambiar dependiendo de ciertas condiciones en tu código VBA.

3. Uso de bucles (Loops) para seleccionar celdas de forma dinámica

Cuando necesitas seleccionar múltiples celdas de forma dinámica, los bucles (loops) son extremadamente útiles. Puedes recorrer filas y columnas usando bucles For o For Each, lo que te permitirá realizar acciones sobre cada celda sin tener que referenciar manualmente cada una.

Por ejemplo, si quieres seleccionar todas las celdas en la columna "A" hasta la fila 10, puedes usar un bucle como este:

For i = 1 To 10
    Sheets("Hoja 1").Cells(i, 1).Select
Next i

Este código seleccionará cada celda en la columna A (desde A1 hasta A10) una por una. Puedes modificarlo fácilmente para recorrer otras columnas o rangos de celdas.

El uso de loops permite automatizar tareas repetitivas de forma eficiente, lo que es una ventaja en la programación de macros en Excel.

4. Consejos adicionales para seleccionar celdas en VBA

Algunos consejos adicionales para trabajar con celdas en VBA:

  • Evita el uso excesivo de .Select: Si bien es útil en algunos casos, es mejor evitar el uso excesivo de la función .Select para optimizar el rendimiento de tus macros.
  • Especifica siempre la hoja de trabajo: Al trabajar con varias hojas, siempre es recomendable especificar la hoja de trabajo para evitar confusión o errores en la selección de celdas.
  • Usa la propiedad .Activate con precaución: Si bien .Activate puede ser útil, puede afectar la visibilidad de las celdas seleccionadas. Utilízala solo cuando sea necesario.

Estos consejos pueden ayudarte a hacer tu código más eficiente y menos propenso a errores. Si quieres aprender más sobre la programación en VBA o necesitas ayuda con otros temas de Excel, consulta nuestros tutoriales o contáctanos para obtener asistencia personalizada.

Encontrar la última celda ocupada en una fila o columna de la hoja Excel

Una de las tareas más comunes al trabajar con hojas de cálculo en Excel y VBA es determinar la última celda ocupada en una fila o columna. Esto es útil cuando necesitas escribir datos de manera eficiente, ya que al identificar la última celda con datos, puedes desplazarte fácilmente a la primera celda vacía para ingresar nuevos valores. Este tutorial te ayudará a encontrar la última celda ocupada en Excel utilizando VBA, optimizando tu flujo de trabajo.

Figura 1. Última celda ocupada.

Cómo Encontrar la Última Celda Ocupada con un Loop en VBA

Una opción para encontrar la última celda ocupada es utilizando un loop en VBA. Aunque no es la más eficiente en términos de rendimiento, este método te permite recorrer todas las celdas de un rango (ya sea una columna o fila) y verificar si están vacías. A continuación te mostramos un ejemplo de cómo escribir en la primera celda vacía tras identificar la última fila ocupada:

Sub getLastRow()
i = 1
 Do
     If IsEmpty(Cells(i, 1)) = True Then Exit Do
     i = i + 1
 Loop
lastRow = i - 1
Cells(lastRow + 1, 1) = "Primera celda disponible" 
End Sub

Este código recorre la columna A y encuentra la última fila ocupada. Luego, se escribe en la primera celda disponible justo después de la última fila con datos.

También puedes adaptar este método para encontrar la última columna ocupada en una fila específica. A continuación te mostramos cómo hacerlo:

Sub getLastColumn()
 j = 1
 Do
     If IsEmpty(Cells(1, j)) = True Then Exit Do
     j = j + 1
Loop 
lastColumn=j - 1
Cells(1, lastColumn + 1) = "Primera celda disponible" 
End Sub

Método Rápido: Encontrar la Última Celda Ocupada sin Loop

Si prefieres un enfoque más rápido y eficiente en términos de rendimiento, te recomendamos usar el método descrito a continuación. Este método es ideal para encontrar la última celda ocupada en una columna específica o en una fila específica sin necesidad de recorrer todas las celdas con un loop. Aquí te mostramos cómo:

Para encontrar la última fila ocupada en una columna, puedes usar el siguiente código:

Variable = celda(Rows.Count, “Referencia de Columna”).End(xlUp).Row

Este código buscará la última fila ocupada en la columna indicada. A continuación, un ejemplo de cómo implementarlo:

Sub getLastRow()
lastRow = Cells(Rows.Count, "A").End(xlUp).Row
Cells(lastRow + 1, 1) = "Primera celda disponible"
End Sub

De manera similar, si necesitas encontrar la última columna ocupada en una fila específica, puedes usar el siguiente código:

Variable = Cells(Índice de fila, Columns.Count).End(xlToLeft).Column

Este comando devuelve el índice de la última columna ocupada en la fila indicada. Aquí tienes un ejemplo:

Sub getLastColumn()
lastColumn = Cells(1, Columns.Count).End(xlToLeft).Column
Cells(1, lastColumn + 1) = "Primera celda disponible"
End Sub

Este método es ideal para optimizar tu código VBA en Excel y mejorar el rendimiento, especialmente cuando trabajas con hojas de cálculo grandes.

Otros Métodos para Encontrar la Última Celda Ocupada

Existen varios métodos para encontrar la última celda ocupada en Excel utilizando VBA. Además de los métodos mencionados anteriormente, aquí te presentamos dos enfoques adicionales que pueden ser útiles según el contexto:

Uso de UsedRange

El objeto UsedRange te permite obtener el rango de celdas en uso, lo cual es útil cuando necesitas determinar rápidamente el área que contiene datos sin tener que recorrer todas las celdas. Aquí te mostramos cómo encontrar la última fila y columna ocupada:

Sub getLastRowUsedRange()
    Dim lastRow As Long
    lastRow = ActiveSheet.UsedRange.Rows.Count
    MsgBox "La última fila ocupada es: " & lastRow
End Sub
Sub getLastColumnUsedRange()
    Dim lastColumn As Long
    lastColumn = ActiveSheet.UsedRange.Columns.Count
    MsgBox "La última columna ocupada es: " & lastColumn
End Sub

Uso de Find

El método Find es una opción muy rápida para encontrar la última celda ocupada en una fila o columna. Utiliza esta técnica si prefieres una búsqueda precisa y eficiente. A continuación te mostramos un ejemplo para encontrar la última fila ocupada:

Sub getLastRowFind()
    Dim lastRow As Long
    On Error Resume Next
    lastRow = Cells.Find(What:="*", After:=[A1], SearchOrder:=xlByRows, SearchDirection:=xlPrevious).Row
    On Error GoTo 0
    MsgBox "La última fila ocupada es: " & lastRow
End Sub

De manera similar, puedes usar Find para encontrar la última columna ocupada:

Sub getLastColumnFind()
    Dim lastColumn As Long
    On Error Resume Next
    lastColumn = Cells.Find(What:="*", After:=[A1], SearchOrder:=xlByColumns, SearchDirection:=xlPrevious).Column
    On Error GoTo 0
    MsgBox "La última columna ocupada es: " & lastColumn
End Sub

¿Quieres saber más sobre cómo mejorar tu productividad en Excel con VBA? ¡Contáctanos!

Bucles en VBA: Optimiza tu Programación

Este tutorial es esencial para comprender cómo los bucles en VBA pueden simplificar tus tareas en Excel. Los lazos o loops son fundamentales en la programación, y entender su funcionamiento te permitirá crear programas más eficientes.

¿Qué es un bucle en programación?

Un loop es la repetición cíclica de una actividad, limitada a un número finito de repeticiones. Un bucle se puede interrumpir al alcanzar el número establecido de repeticiones o al cumplirse una condición específica. Para más información sobre condicionales, revisa nuestro tutorial sobre Condicionales en VBA.

Definición de un Loop en programación
Figura 1. Definición de un Loop en programación.

Tipos de bucles en VBA

En VBA, existen dos estructuras principales para implementar bucles: For / Next y Do / Loop. Cada una tiene características únicas que la hacen adecuada para diferentes situaciones. A continuación, exploraremos ambos tipos con ejemplos prácticos.

Estructura For Next

La estructura For Next permite realizar una acción repetitiva desde un número inicial (NI) hasta un número final (NF). A continuación, se muestra un ejemplo de cómo se puede estructurar un bucle For:

NI NF Total de repeticiones
1 10 10
10 19 10
81 91 10

El número de repeticiones debe ser un entero. La estructura For Next se declara de la siguiente manera:

For Variable = NI To NF Step incremento Declaración del lazo
Actividad repetitiva Actividad
Next Declaración del lazo

Ejemplo del bucle For Next en VBA

A continuación, veremos cómo encontrar la última celda ocupada en un rango utilizando un bucle For Next:

Ejemplo estructura For Next
Figura 2. Ejemplo de la estructura For Next.
Sub Tutorial5a_Loops()
For i = 1 To 10
  If Cells(i + 1, 1) = "" Then
    Ultima_fila = i 
    Exit For
  End If
Next
MsgBox ("Última fila: " & Ultima_fila)
End Sub

En este código, el programa verifica si la celda está vacía, y si es así, se detiene y muestra la última fila ocupada.

Estructura Do Loop

La estructura Do Loop no incrementa automáticamente la variable de repetición. Ofrece tres modalidades que permiten un control más flexible:

Modalidad Do

Esta forma permite declarar el bucle y especificar la condición de salida. Debe usarse con precaución para evitar bucles infinitos.

Do Declaración del lazo
Actividad repetitiva Actividad
Variable=Variable+1 Control del número de repetición
Loop Declaración del lazo

Ejemplo del bucle Do Loop en VBA

El siguiente ejemplo muestra cómo encontrar la última fila ocupada utilizando Do Loop:

Ejemplo estructura Do
Figura 3. Ejemplo de la estructura Do.
Sub Tutorial5b_Loops()
i = 2
Do
  If Cells(i, 1) = "" Then
    Ultima_fila = i - 1
    Exit Do
  End If
  i = i + 1
Loop
MsgBox ("Última fila: " & Ultima_fila)
End Sub

Modalidad Do While

Esta modalidad se ejecuta mientras se cumpla una condición especificada. Veamos cómo aplicarla:

Estructura Do While
Figura 4. Estructura Do While.
Sub Tutorial5c_Loops()
i = 2
Do While Cells(i, 1) <> ""
  'Actividad repetitiva
  i = i + 1
Loop
Ultima_fila = i - 1
MsgBox ("Última fila: " & Ultima_fila)
End Sub

Modalidad Do Until

Esta modalidad se ejecuta hasta que se cumpla una condición. Aquí hay un ejemplo:

Ejemplo estructura Do Until
Figura 5. Ejemplo de la estructura Do Until.
Sub Tutorial5d_Loops()
i = 2
Do Until Cells(i, 1) = ""
  'Actividad repetitiva
  i = i + 1
Loop
Ultima_fila = i - 1
MsgBox ("Última fila: " & Ultima_fila)
End Sub

Como puedes ver, el bucle se ejecuta hasta encontrar la primera celda vacía.

Conclusión

Con lo aprendido en este tutorial, podrás utilizar las estructuras de bucles en VBA sin dificultad. Se recomienda evitar la modalidad Do por el riesgo de bucles infinitos. Opta por For Next, Do While o Do Until para un control más seguro y efectivo.

¿Quieres saber más? Contáctanos...

Uso del condicional If en VBA (if, elseif, else, end if)

A partir de este tutorial, empezaremos a explorar las bondades de programar, siendo una de ellas la capacidad de hacer que el computador “tome decisiones” a través de los condicionales.

¿Qué es un Condicional?

Un condicional es una evaluación que se realiza en el flujo de la información (una o más variables) y permite discernir si se cumple o no con una condición establecida. Según la respuesta, se tomarán diferentes acciones.

¿Cómo Escribir un Condicional en VBA?

Para escribir un condicional (If en VBA), debemos evaluar una variable y dar instrucciones sobre qué hacer si se cumple la condición. Esta evaluación se realiza utilizando el comando If.

Ejemplo de Condicional If en VBA: Entradas al Cine

Imaginemos que estamos creando un sistema para vender entradas de cine, donde el precio de la entrada depende de la edad del espectador. En este caso, definimos las siguientes reglas:

  • Los niños de 12 años o menos recibirán una entrada "Preferencial".
  • Los adultos mayores de 12 años recibirán una entrada "Regular".

Para implementar estas reglas en VBA, utilizaremos una estructura condicional If que evaluará la edad ingresada en la celda B2. Si la edad es menor o igual a 12, se asignará "Preferencial" a la celda C2. De lo contrario, se asignará "Regular". Aquí tienes el código correspondiente:


Sub AsignarEntrada()
    Dim edad As Integer
    ' Leer la edad de la celda B2
    edad = Range("B2").Value

    ' Evaluar la condición
    If edad <= 12 Then
        Range("C2") = "Preferencial" ' Entrada para niños
    Else
        Range("C2") = "Regular" ' Entrada para adultos
    End If
End Sub

En este ejemplo, si el usuario ingresa un valor en la celda B2 (por ejemplo, 10), el sistema evaluará la condición:

  • Si 10 <= 12 es verdadero, la celda C2 mostrará "Preferencial".
  • Si el usuario ingresa 15, el sistema evaluará 15 <= 12, lo que es falso, y la celda C2 mostrará "Regular".

Condicionales If Anidados en VBA

A veces, es necesario evaluar una segunda condición después de la primera evaluación. Esto se denomina "Condicional Anidado". La estructura será similar a la siguiente:

Ejemplo de Condicional If Anidado en VBA

Continuando con el ejemplo de la entrada al cine, podríamos agregar una evaluación adicional. Supongamos que queremos ofrecer entradas "Preferenciales" también a personas de tercera edad (mayores de 59 años). El código podría verse así:


Sub AsignarEntradaCompleta()
    Dim edad As Integer
    edad = Range("B2").Value

    If edad <= 12 Then
        Range("C2") = "Preferencial" ' Entrada para niños
    ElseIf edad > 59 Then
        Range("C2") = "Preferencial" ' Entrada para tercera edad
    Else
        Range("C2") = "Regular" ' Entrada para adultos
    End If
End Sub

Uso de Or y And (Operadores Lógicos) en Condicionales VBA

También es posible evaluar múltiples condiciones en un mismo condicional usando los operadores lógicos And y Or.

Ejemplos de Uso de Or y And en Condicionales de VBA

Si queremos considerar un rango de edad para las entradas "Regular", podemos usar el operador And:


Sub AsignarEntradaConOperadores()
    Dim edad As Integer
    edad = Range("B2").Value

    If edad > 12 And edad < 60 Then
        Range("C2") = "Regular"
    Else
        Range("C2") = "Preferencial"
    End If
End Sub

De manera similar, usando el operador Or podemos evaluar si una entrada es "Preferencial" si la edad es menor a 13 o mayor a 59:


Sub AsignarEntradaConOr()
    Dim edad As Integer
    edad = Range("B2").Value

    If edad < 13 Or edad > 59 Then
        Range("C2") = "Preferencial"
    Else
        Range("C2") = "Regular"
    End If
End Sub

Conclusiones

Como has visto, hay diferentes formas de programar instrucciones de decisión en VBA, y cada método tiene sus ventajas. Con la práctica, mejorarás en la escritura de código más compacto y libre de errores.

¿Quieres saber más? Contáctanos...

Guía Completa sobre Variables en VBA: Aprende a Declararlas y Usarlas

¿Qué son las Variables en VBA y por qué se usan?

Las variables son elementos fundamentales en cualquier lenguaje de programación, incluyendo VBA. Permiten almacenar y manipular datos, como números, texto y estructuras más complejas. Al declarar variables adecuadamente, optimizamos el uso de memoria y mejoramos la velocidad de ejecución del código.

Analogía de la Vida Real: Imagina que estás organizando un armario. Si lo haces de manera ordenada, podrás encontrar tus prendas rápidamente y aprovechar mejor el espacio. Lo mismo ocurre con las variables en programación: al gestionarlas correctamente, optimizamos su uso y capacidad.

El buen manejo de las variables contribuye con el orden y la eficiencia del código.

El buen manejo de las variables contribuye con el orden y la eficiencia del código.

¿Qué es la Declaración de Variables en VBA?

La declaración de variables consiste en instruir al sistema para reservar un espacio de memoria según el tipo de variable que se necesita. Aunque en VBA no es obligatorio declarar variables, hacerlo previene la ralentización del programa, ya que VBA no tendrá que determinar el tipo de variable cada vez que se encuentre con una no definida.

Tipos de Variables en VBA

Las variables en VBA ocupan diferentes cantidades de memoria según su tipo. A continuación, se presentan algunos de los tipos de variables más comunes:

Tipo de Variable Denominación en VBA Espacio Ocupado (bytes) Rango de Valores Ejemplo
Booleana Boolean 2 Verdadero o Falso Answer = True
Entero Integer 2 -32,768 ↔ 32,767 Cant = 5
Doble Precisión Double 8 ±1.79769313486232 × 10^308 Pi = 3.14159265
Moneda Currency 8 -922,337,203,685,477 ↔ 922,337,203,685,477 Monto = 5.5
Texto String 1 por carácter Cualquier texto Prod = "Carro"
Variable Especial Variant Varía Varía según el tipo de datos Total = Pi * Cant

VBA asigna automáticamente la categoría Variant a las variables no declaradas. Es recomendable declarar el tipo de variable para optimizar el uso de memoria y mejorar el rendimiento.

Niveles de Variables en VBA

En VBA, las variables pueden ser públicas (Public) o privadas (Private), dependiendo de su nivel de accesibilidad:

Tipo de Variable Usada en
Privada Un mismo procedimiento (rutina o función) en un mismo módulo
Pública Todos los procedimientos de todos los módulos

Las variables privadas pueden tener el mismo nombre en procedimientos diferentes, ya que no son compartidas. Por el contrario, las variables públicas mantienen su valor activo mientras se ejecute la macro.

¿Cómo Declarar una Variable en VBA?

Para declarar una variable, sigue estos pasos:

  1. Abre el editor de comandos de VBA (puedes consultar nuestro primer tutorial sobre macros en Excel).
  2. Utiliza la instrucción Dim para declarar la variable.

Ejemplo de Declaración:

Dim pi As Double

En este caso, estamos reservando espacio para la variable pi, que almacenará un número de doble precisión.

Mostrar el Resultado: Para imprimir el valor, utiliza MsgBox:

MsgBox(pi)

Consejos para el Uso de Variables en VBA

  • Para obligar a VBA a declarar siempre las variables, usa Option Explicit al principio de cualquier módulo. Esto te ayudará a evitar errores de declaración.
  • Si olvidas declarar una variable, VBA resaltará el error, facilitando su identificación y corrección.
  • Utiliza la combinación CTRL + Espacio para acceder a un menú de variables declaradas al escribir.

Sobre los Nombres de las Variables en VBA

Elige nombres descriptivos para tus variables, ya que esto facilita la comprensión del código. Algunas reglas a seguir son:

  • El primer carácter debe ser una letra.
  • VBA no distingue entre mayúsculas y minúsculas; Var y var son la misma variable.
  • No se permiten espacios ni ciertos símbolos en los nombres.
  • El máximo número de caracteres para un nombre de variable es 255.

¿Quieres saber más? Contáctanos...

Uso de la grabadora de macros de Excel

La grabadora de macros es una utilidad que te ayuda a dar los primeros pasos en el mundo de la programación en Visual Basic for Applications (VBA), y para los que tienen ya un camino recorrido en este mundo VBA, permite aclarar dudas sobre cómo hacer ciertas actividades repetitivas mediante la revisión de las instrucciones en el editor de comandos. Si quieres saber como se utiliza la grabadora de macros de Excel o como grabar una macro en Excel, estás en el sitio indicado.

Cuando actives esta utilidad, se grabará lo que hagas en el los programas de Office; puede ser utilizado en Excel y otros paquetes de Office como Word y PowerPoint. En este sencillo ejemplo que haremos a continuación, grabaremos como hacer automáticamente el cambio de formato de celdas y texto, así como desplazarnos entre celdas vecinas y como repetir la secuencia con sólo con hacer un Click.

Activar la grabadora de macros

Para activarla debes ir a la pestaña “DESARROLLADOR” y ubicar el icono de la grabadora de macros.

Figura 1. Ubicación de la grabadora de macros.

Alternativamente la puedes ubicar en la pestaña “VISTA” seleccionando el comando “Grabar Macro…” del menú “Macros”.

Figura 2. Ubicación alternativa de la grabadora de macros.

Preparar la grabación de la macro

Aparecerá una la ventana “Grabar macro”, allí le colocarás a tu macro el nombre que se desees. También tendrás la opción de asignarle una combinación de teclas que te permitirán correr tu macro de una forma rápida. Si no le asignas la “Tecla de método abreviado” podrás acceder a tu macro a través de otra forma que te la explicaremos más adelante.

A esta macro la denominaremos “Mi_Segunda_Macro” y su método abreviado será “CTRL + m”.

Figura 3. Grabar Macro.

Cuando presionemos Aceptar, se iniciará la grabación. Es importante saber que a partir de este momento, cualquier acción que hagamos dentro de Office: integradamente Word, Excel y los demás programas del paquete, será grabada.

Sabremos que la grabadora está corriendo porque en el lugar que aparecía “Grabar macro” ahora aparecerá “Detener Grabación”.

Grabar la macro de Excel

En esta macro, una vez hayas seleccionado la celda A1, grabaremos las siguientes acciones:

  • Cambiarle el relleno a la celda “A1” a color amarillo.
  • Seleccionar con el mouse o desplazarse con el teclado hasta la celda “B1” y modificarle el formato del texto colocándolo color Naranja.
  • Similarmente, pasar a la celda “C1” y cambiarle el color del texto a azul.
  • Repetiremos el paso con la celda combinada “B2:C2” al cambiarle el color del texto a Marrón.
  • Selecciona las celdas “A1:C2” y cámbiale el tipo y tamaño de letra a “Arial Narrow” 18 pt.
Figura 4. Antes y después de ejecutar la macro.

Cómo se detiene la grabación de la macro de Excel?

Una vez completadas todas las actividades que queremos dejar en la macro, es necesario detener la grabación presionando el comando “Detener grabación”.

Figura 5. Detener la grabación.

Revisar la secuencia de comandos en VBA

Tal y como vimos en el primer tutorial, podemos entrar al editor de comandos de VBA y ver lo que fue grabado. Esta actividad es opcional, sólo debes realizarla si necesitas complementar algo o si ya tienes cierta experiencia.

Figura 6. Editor de comandos de VBA.
Sub Mi_Segunda_Macro()
'
' Mi_Segunda_Macro Macro
'
' Acceso directo: CTRL+m
'
With Selection.Interior
.Pattern = xlSolid
.PatternColorIndex = xlAutomatic
.Color = 65535
.TintAndShade = 0
.PatternTintAndShade = 0
End With
Range("B1").Select
With Selection.Font
.Color = -16750849
.TintAndShade = 0
End With
Range("C1").Select
With Selection.Font
.ThemeColor = xlThemeColorAccent1
.TintAndShade = -0.249977111117893
End With
Range("B2:C2").Select
With Selection.Font
.Color = -16764058
.TintAndShade = 0
End With
Range("A1:C2").Select
Range("B2").Activate
With Selection.Font
.Name = "Calibri"
.Size = 18
.Strikethrough = False
.Superscript = False
.Subscript = False
.OutlineFont = False
.Shadow = False
.Underline = xlUnderlineStyleNone
.TintAndShade = 0
.ThemeFont = xlThemeFontMinor
End With
Range("A1").Select
End Sub

Ejecutar nuevamente la macro de Excel

La secuencia que acabas de grabar será repetida cada vez que ejecutes tu macro a partir del comando “Macro” que encontrarás en la pestaña “DESARROLLADOR”. Se mostrará un cuadro donde veras en forma de lista todas las macros que hayas grabado. Sólo deberás seleccionar la macro que desees utilizar y luego presionar “Ejecutar”.

Figura 7. Ubicación de macros grabadas.

También podrás ejecutar la macro mediante el método abreviado que le hayas asignado, en este caso lo colocamos como “CTRL + m”.

Alternativamente podremos acceder a la listas de macros grabadas a través del comando “Ver macros” que está ubicado en el menú “Macros” de la pestaña “VISTA”.

Figura 8. Ubicación alternativa de las macros grabadas.

Esta macro modifica el formato de las casillas; esta acción se repetirá independientemente del texto que esté en estas celdas, inclusive si las celdas están vacías. Puedes probar como funciona nuestra macro cambiando el texto y luego ejecutándola; veras que cada celda toma el formato de texto que le indicamos al grabar la macro.

Figura 9. Antes y después de ejecutar la macro con otro texto.

Quieres saber más? Contáctanos...

 

 

Mi Primera Macro en Excel

¿Qué es una macro de Excel?

Si eres un usuario de Excel seguramente te has encontrado en la necesidad de ejecutar tareas repetitivas. Pues bien, las macros permiten automatizar esas tareas repetitivas para ahorrarte tiempo y esfuerzo a la hora de trabajar en Excel, así que si quieres aprender como usarlas has llegado al sitio correcto. 

El lenguaje en el que se se escriben las macros de Excel se llama Visual Basic for Applications, más conocido como VBA. La buena noticia es que no tienes que ser un experto en programación para iniciar en este mundo.

En este primer tutorial te enseñaremos a crear tu primera Macro en Excel. Se trata de hacer aparecer un mensaje que diga "Hello World!". Para ello sigue los siguientes pasos:

Activar la pestaña de Desarrollador en Excel

En primer lugar, debemos estar seguros de tener activa la pestaña “DESARROLLADOR” en la cinta de opciones, ya que la misma dispone de opciones de interés para los programadores.

Para ello, abre un nuevo archivo de Excel y observa si esta pestaña está disponible.

En caso contrario, haz clic derecho en cualquier parte de la cinta de opciones y selecciona la opción “Personalizar la cinta de opciones…”. Luego activa la casilla de “Desarrollador” y presiona “Aceptar”.

Ingresar al editor VBA

El ingreso a al editor VBA puede darse por dos vías:
a) Mediante la combinación de teclas Alt + F11
b) Presionando el botón “Ver código” en la cinta de opciones “DESARROLLADOR”

Agregar un nuevo módulo en VBA

Dentro del entorno VBA, haz clic derecho en la carpeta de proyecto del libro de Excel (usualmente ubicada en la parte izquierda de la pantalla). Del menú desplegable selecciona Insertar / Módulo

Escribir el programa en VBA

Escribiremos un programa que emita el mensaje “Hello World!”. Para ello crearemos una subrutina (Sub) que llamaremos “MiPrimeraMacro”. El nombre de la subrutina no debe contener espacios ni caracteres especiales. El comienzo de la subrutina está denotado con la palabra “Sub”, y el final con la frase “End Sub” .

Dentro de la subrutina definiremos una variable de tipo “string” (hablaremos más adelante sobre los tipos de variables) que almacenará el texto a mostrar. A esta variable le asignaremos el nombre  “strSaludo”. El código debe lucir como se indica a continuación:

Sub MiPrimeraMacro()
     Dim strSaludo As String
   
     strSaludo = "Hello World!"
  
     MsgBox strSaludo
  
End Sub 
 

Ejecutar el programa en VBA

El programa los podemos ejecutar desde distintas vías:
a) Presionando la tecla F5
b) Presionando el botón de Ejecutar macro

c) Asignando la macro a un botón. Para ello ve a la pestaña “DESARROLLADOR” y selecciona “Insertar/Botón”. Luego haz clic en cualquier parte de la hoja para seleccionar la posición del botón. Excel preguntará por el nombre de la macro asociada a ese botón; selecciona “MiPrimeraMacro” y presiona aceptar.

Una vez que ejecutes la macro debe aparecer el siguiente mensaje:

¡Felicidades! Haz escrito tu primera macro.Guardar el libro Excel habilitado para macros

Asegúrate de guardar los documentos que contengan macros bajo la extensión “.xlsm” (habilitado para macros).

 

 

 

 

Quieres saber más? Contáctanos...