Comment empêcher le copier-coller sur une cellule avec liste déroulante dans Excel ?
Pour une cellule avec une liste déroulante de validation des données, lorsque vous copiez du contenu à partir d'une autre cellule et le collez dedans, la liste déroulante disparaîtra et sera remplacée par le nouveau contenu collé. Dans certains cas, vous souhaitez empêcher le collage d'un autre contenu sur la cellule contenant une liste déroulante. Que feriez-vous pour résoudre ce problème ? Dans cet article, vous découvrirez une méthode VBA pour traiter cette situation.
Empêcher le copier-coller sur une cellule avec liste déroulante dans Excel
Empêcher le copier-coller sur une cellule avec liste déroulante dans Excel
1. Ouvrez la feuille de calcul contenant la cellule avec liste déroulante que vous souhaitez protéger contre le copier-coller.
2. Appuyez simultanément sur les touches Alt + F11 pour ouvrir la fenêtre Microsoft Visual Basic Applications.
3. Dans la fenêtre Microsoft Visual Basic Applications, double-cliquez sur le nom de la feuille de calcul actuelle dans le volet de gauche, puis copiez-collez le code VBA ci-dessous dans l'éditeur de Code. Voir capture d'écran :
Code VBA : Empêcher le copier-coller sur une cellule avec liste déroulante
Private Sub Worksheet_Change(ByVal Target As Range)
'Updated by Extendoffice 20200903
Dim xValue As String
Dim xCheck1 As String
Dim xCheck2 As String
Dim xRg As Range
Dim xArrCheck1() As String
Dim xArrCheck2() As String
Dim xArrValue()
Dim xCount, xJ As Integer
Dim xBol As Boolean
' If Target.Count > 1 Then
' Exit Sub
' End If
xCount = Target.Count
ReDim xArrCheck1(1 To xCount)
ReDim xArrCheck2(1 To xCount)
ReDim xArrValue(1 To xCount)
Application.EnableEvents = False
On Error Resume Next
xJ = 1
For Each xRg In Target
xArrValue(xJ) = xRg.Value
xArrCheck1(xJ) = xRg.Validation.InCellDropdown
xJ = xJ + 1
Next
Application.Undo
xJ = 1
For Each xRg In Target
xArrCheck2(xJ) = xRg.Validation.InCellDropdown
xJ = xJ + 1
Next
xBol = False
For xJ = 1 To xCount
If xArrCheck2(xJ) <> xArrCheck1(xJ) Then
xBol = True
Exit For
End If
Next
If xBol Then
MsgBox "The selected cells containg data validation drop-down lists, no pasting allowed."
Else
xJ = 1
For Each xRg In Target
xRg.Value = xArrValue(xJ)
xJ = xJ + 1
Next
End If
Application.EnableEvents = True
End Sub
4. Appuyez sur les touches Alt + Q pour quitter la fenêtre Microsoft Visual Basic Applications.
5. Lorsque vous collez du contenu dans une cellule avec une liste déroulante, une boîte de dialogue apparaîtra pour vous rappeler que le collage n'est pas autorisé. Voir capture d'écran :
Remarque : Ce code VBA fonctionne uniquement pour le collage dans une seule cellule. Si vous copiez et collez dans plusieurs cellules, il ne fonctionnera pas.
Créer facilement une liste déroulante avec cases à cocher dans Excel :
L'utilitaire Liste déroulante avec cases à cocher de Kutools for Excel peut vous aider à créer facilement une liste déroulante avec cases à cocher dans une plage spécifiée, la feuille de calcul actuelle, le classeur actuel ou tous les classeurs ouverts en fonction de vos besoins.
Téléchargez dès maintenant la version d’essai gratuite de 30 jours de Kutools for Excel avec toutes les fonctionnalités !
Articles connexes :
Comment créer une liste déroulante avec plusieurs cases à cocher dans Excel ?
De nombreux utilisateurs d'Excel ont tendance à créer une liste déroulante avec plusieurs cases à cocher afin de sélectionner plusieurs éléments de la liste à la fois. En réalité, vous ne pouvez pas créer une liste avec plusieurs cases à cocher via la validation des données. Dans ce tutoriel, nous allons vous montrer deux méthodes pour créer une liste déroulante avec plusieurs cases à cocher dans Excel. Ce tutoriel fournit une solution au problème.
Créer une liste déroulante à partir d'un autre classeur dans Excel
Il est assez simple de créer une liste déroulante de validation des données entre plusieurs feuilles de calcul dans un même classeur. Mais si les données nécessaires pour la validation se trouvent dans un autre classeur, que feriez-vous ? Dans ce tutoriel, vous apprendrez comment créer une liste déroulante à partir d’un autre classeur dans Excel en détail.
Créer une liste déroulante consultable dans Excel
Pour une liste déroulante contenant de nombreuses valeurs, trouver celle qui convient peut s'avérer difficile. Auparavant, nous avons introduit une méthode permettant d'auto-compléter la liste déroulante lorsqu'on saisit la première lettre dans la zone de liste déroulante. Outre la fonction d'auto-complétion, vous pouvez également rendre la liste déroulante consultable pour améliorer l'efficacité de recherche des bonnes valeurs dans la liste. Pour rendre votre liste déroulante consultable, essayez la méthode décrite dans ce tutoriel.
Remplir automatiquement d'autres cellules lors de la sélection de valeurs dans une liste déroulante Excel
Disons que vous avez créé une liste déroulante basée sur les valeurs de la plage de cellules B8:B14. Lorsque vous sélectionnez une valeur dans la liste déroulante, vous souhaitez que les valeurs correspondantes dans la plage C8:C14 soient automatiquement remplies dans une cellule sélectionnée. Pour résoudre ce problème, les méthodes de ce tutoriel vous seront utiles.
Meilleurs outils de productivité pour Office
Boostez vos compétences Excel avec Kutools pour Excel, et découvrez une efficacité sans précédent. Kutools pour Excel propose plus de300 fonctionnalités avancées pour augmenter la productivité et gagner du temps. Cliquez ici pour obtenir la fonctionnalité dont vous avez le plus besoin...
Office Tab apporte une interface à onglets à Office, et facilite grandement votre travail
- Activez la modification 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é de50 %, et réduit des centaines de clics de souris pour vous chaque jour !