Passer au contenu principal

Comment rendre le nom du bouton de commande dynamique dans Excel?

Cet article parle de faire le nom d'un bouton de commande changé dynamiquement avec une modification de valeur de cellule spécifiée. Par exemple, lorsque la valeur de la cellule A1 a été remplacée par «test», le nom d'un certain bouton de commande sera automatiquement remplacé par «test».

Rendre le nom du bouton de commande dynamique avec la valeur de la cellule par code VBA


Rendre le nom du bouton de commande dynamique avec la valeur de la cellule par code VBA

Le code VBA suivant peut vous aider à rendre le nom d'un bouton de commande dynamique avec une valeur de cellule spécifiée dans une feuille de calcul. Veuillez faire comme suit.

1. Cliquez Développeur > insérer > Bouton de commande (contrôle ActiveX) pour insérer un bouton de commande dans la feuille de calcul. Voir la capture d'écran:

2. Après avoir inséré le bouton de commande, cliquez avec le bouton droit sur l'onglet de la feuille et cliquez sur Voir le code dans le menu contextuel comme ci-dessous la capture d'écran montrée:

3. Dans l'ouverture Microsoft Visual Basic pour applications fenêtre, veuillez copier et coller ci-dessous le code VBA dans la fenêtre.

Code VBA: rendre le nom du bouton de commande dynamique avec la valeur de la cellule

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

Notes: dans le code, CommandButton1 est le nom du bouton dont vous voulez rendre son nom dynamique, et A1 est la cellule dont vous référencerez automatiquement la valeur au nom du bouton.

4. appuie sur le autre + Q touches pour quitter Microsoft Visual Basic pour applications fenêtre.

5. Désactivez le mode de conception en cliquant sur Développeur > Mode de conception.

À partir de maintenant, le nom du bouton de commande sera modifié dynamiquement avec la valeur de cellule spécifiée dans votre feuille de calcul.

Comme illustré ci-dessous, lorsque la valeur de la cellule A1 a été modifiée, le nom du bouton de commande sera automatiquement remplacé par la même valeur.


Articles connexes:

Meilleurs outils de productivité bureautique

Caractéristiques populaires: Rechercher, mettre en évidence ou identifier les doublons   |  Supprimer les lignes vides   |  Combinez des colonnes ou des cellules sans perdre de données   |   Tour sans formule 
Super recherche: VSearchup à critères multiples    VSearch à valeurs multiples  |   Recherche virtuelle sur plusieurs feuilles   |   Recherche floue ....
Liste déroulante avancée: Créez rapidement une liste déroulante   |  Liste déroulante dépendante   |  Liste déroulante à sélection multiple ....
Gestionnaire de colonnes: Ajouter un nombre spécifique de colonnes  |  Déplacer les colonnes  |  Basculer l'état de visibilité des colonnes masquées  |  Comparer les plages et les colonnes 
Caractéristiques en vedette: Mise au point de la grille   |  Voir Design   |   Grande barre de formule    Gestionnaire de classeurs et de feuilles   |  Centre de ressources (Texte automatique)   |  Sélecteur de date   |  Combiner des feuilles de travail   |  Crypter/déchiffrer les cellules    Envoyer des e-mails par liste   |  Super filtre   |   Filtre spécial (filtre gras/italique/barré...) ...
Les 15 meilleurs ensembles d'outils12 Texte Outils (Ajouter du texte, Supprimer les caractères, ...)   |   50+ Graphique Types (Diagramme de Gantt, ...)   |   40+ Pratique Formules (Calculer l'âge en fonction de l'anniversaire, ...)   |   19 Insertion Outils (Insérer le code QR, Insérer une image à partir du chemin, ...)   |   12 Conversion Outils (Nombres en mots, Conversion des devises, ...)   |   7 Fusionner et fractionner Outils (Lignes de combinaison avancées, Cellules divisés, ...)   |   ... et plus

Améliorez vos compétences Excel avec Kutools for Excel et faites l'expérience d'une efficacité comme jamais auparavant. Kutools for Excel offre plus de 300 fonctionnalités avancées pour augmenter la productivité et gagner du temps.  Cliquez ici pour obtenir la fonctionnalité dont vous avez le plus besoin...

onglet kte 201905


Office Tab apporte une interface à onglets à Office et facilite grandement votre travail

  • Activer l'édition et la lecture par onglets dans Word, Excel, PowerPoint, Publisher, Access, Visio et Project.
  • Ouvrez et créez plusieurs documents dans de nouveaux onglets de la même fenêtre, plutôt que dans de nouvelles fenêtres.
  • Augmente votre productivité de 50% et réduit des centaines de clics de souris chaque jour!
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