Saltar al contenido principal

¿Cómo hacer que el nombre del botón de comando sea dinámico en Excel?

Este artículo habla de cómo hacer que el nombre de un botón de comando cambie dinámicamente con un cambio de valor de celda especificado. Por ejemplo, cuando el valor de la celda A1 se ha cambiado a "prueba", el nombre de un determinado botón de comando se cambiará a "prueba" automáticamente.

Hacer que el nombre del botón de comando sea dinámico con el valor de la celda por código VBA


Hacer que el nombre del botón de comando sea dinámico con el valor de la celda por código VBA

El siguiente código de VBA puede ayudarlo a hacer que el nombre de un botón de comando sea dinámico con un valor de celda específico en una hoja de trabajo. Haz lo siguiente.

1. Hacer clic en Developer > recuadro > Botón de comando (control ActiveX) para insertar un botón de comando en la hoja de trabajo. Ver captura de pantalla:

2. Después de insertar el botón de comando, haga clic con el botón derecho en la pestaña de la hoja y haga clic en Ver código desde el menú contextual como se muestra a continuación:

3. En la apertura Microsoft Visual Basic para aplicaciones ventana, copie y pegue el código VBA debajo en la ventana.

Código VBA: haga que el nombre del botón de comando sea dinámico con el valor de la celda

Dim xStr As String
Private Sub Worksheet_Change(ByVal Target As Range)
    Dim xShapeRg As ShapeRange
    On Error Resume Next
    If Not Application.Intersect(Target, Range("A1")) Is Nothing Then
        Me.CommandButton1.Caption = Target.Text
        Set xShapeRg = ActiveSheet.Shapes.Range(xStr)
        If xShapeRg Is Nothing Then Set xShapeRg = ActiveSheet.Shapes.Range("CommandButton1")
        Application.EnableEvents = False
        xShapeRg.Select
        Application.EnableEvents = True
        Selection.Name = Target.Text
    End If
End Sub
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    If (Not Intersect(Target, Range("A1")) Is Nothing) And Target.Text <> "" Then
        xStr = Target.Text
    End If
End Sub

Note: en el código, CommandButton1 es el nombre del botón cuyo nombre desea que sea dinámico, y A1 es la celda a la que hará referencia automáticamente el valor al nombre del botón.

4. presione el otro + Q llaves para salir del Microsoft Visual Basic para aplicaciones ventana.

5. Desactive el modo de diseño haciendo clic en Developer > Modo de diseño.

De ahora en adelante, el nombre del botón de comando se cambiará dinámicamente con el valor de celda especificado en su hoja de trabajo.

Como se muestra a continuación, cuando se cambia el valor de la celda A1, el nombre del botón de comando se cambiará al mismo valor automáticamente.


Artículos relacionados:

Las mejores herramientas de productividad de oficina

🤖 Asistente de IA de Kutools: Revolucionar el análisis de datos basado en: Ejecución inteligente   |  Generar codigo  |  Crear fórmulas personalizadas  |  Analizar datos y generar gráficos  |  Invocar funciones de Kutools...
Características populares: Buscar, resaltar o identificar duplicados   |  Eliminar filas en blanco   |  Combine columnas o celdas sin perder datos   |   Ronda sin fórmula ...
Super búsqueda: Búsqueda virtual de criterios múltiples    Búsqueda V de valores múltiples  |   VLookup en varias hojas   |   Búsqueda difusa ....
Lista desplegable avanzada: Crear rápidamente una lista desplegable   |  Lista desplegable dependiente   |  Lista desplegable de selección múltiple ....
Administrador de columnas: Agregar un número específico de columnas  |  Mover columnas  |  Toggle Estado de visibilidad de columnas ocultas  |  Comparar rangos y columnas ...
Características destacadas: Enfoque de cuadrícula   |  Vista de diseño   |   Gran barra de fórmulas    Administrador de hojas y libros de trabajo   |  Biblioteca de Recursos (Texto automático)   |  Selector de fechas   |  Combinar hojas de trabajo   |  Cifrar/descifrar celdas    Enviar correos electrónicos por lista   |  Súper filtro   |   Filtro especial (filtro negrita/cursiva/tachado...) ...
Los 15 mejores conjuntos de herramientas12 Texto Herramientas (Añadir texto, Quitar caracteres, ...)   |   50+ Tabla Tipos (Diagrama de Gantt, ...)   |   40+ Práctico Fórmulas (Calcular la edad según el cumpleaños, ...)   |   19 Inserción Herramientas (Insertar código QR, Insertar imagen desde la ruta, ...)   |   12 Conversión Herramientas (Números a palabras, Conversión de Moneda, ...)   |   7 Fusionar y dividir Herramientas (Filas combinadas avanzadas, Células partidas, ...)   |   ... y más

Mejore sus habilidades de Excel con Kutools for Excel y experimente la eficiencia como nunca antes. Kutools for Excel ofrece más de 300 funciones avanzadas para aumentar la productividad y ahorrar tiempo.  Haga clic aquí para obtener la función que más necesita...

Descripción


Office Tab lleva la interfaz con pestañas a Office y hace que su trabajo sea mucho más fácil

  • Habilite la edición y lectura con pestañas en Word, Excel, PowerPoint, Publisher, Access, Visio y Project.
  • Abra y cree varios documentos en nuevas pestañas de la misma ventana, en lugar de en nuevas ventanas.
  • ¡Aumenta su productividad en un 50% y reduce cientos de clics del mouse todos los días!
Comments (2)
No ratings yet. Be the first to rate!
This comment was minimized by the moderator on the site
Can anyone suggest how I would extend the VBA to additionally assign a macro to the command button so clicking the command button would execute a macro associated with the command button name? For example, after renaming the command button to "XYZ", also assign the macro named "XYZ" to the command button click event. Thank you for any help.
This comment was minimized by the moderator on the site
Hi sam,
Please try as follows.
1. Turn on the Design Mode by clicking Developer > Design Mode.
2. Right click the command button and select View Code in the context menu;
3. Assign your macro between line Private Sub CommandButton1_Click() and End Sub;
4. Turn off the Design Mode

Hope I can help.
There are no comments posted here yet
Please leave your comments in English
Posting as Guest
×
Rate this post:
0   Characters
Suggested Locations