IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

Validation de Données - message de saisie uniquement [XL-2016]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Janvier 2013
    Messages
    660
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2013
    Messages : 660
    Par défaut Validation de Données - message de saisie uniquement
    Bonjour,

    Dans ce bout de code, je souhaite récupérer, en guise d'info-bulle, les contenus de la colonne A et de la ligne 4 (dates) relatifs à la cellule sélectionnée.

    Ça bug sur la ligne "Add Type (...)" :
    'Erreur d'exécution '1004": Erreur définition par l'application ou par l'objet
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    Private Sub Worksheet_SelectionChange(ByVal target As Range)
    Dim zone_saisies As String
     
        zone_saisies = "e10:ng34"
     
            With Selection.Validation
               .Delete
               .Add Type:=xlValidateInputOnly, AlertStyle:=xlValidAlertStop, Operator:=xlBetween
    '            .IgnoreBlank = True
    '            .InCellDropdown = True
    '            .InputTitle = "Titre"
    '            .ErrorTitle = ""
                .InputMessage = Range("A" & ActiveCell.Row).Value & Chr(10) & Format(Cells([4], target.Column).Value, "ddd dd mmm")
    '            .ErrorMessage = ""
    '            .ShowInput = True
    '            .ShowError = True
            End With
    End Sub
    A noter que dans certaines conditions (que je n'ai pas pu clairement identifier), le résultat s'est affiché correctement. Néanmoins, il ne s'affiche jamais pour certaines lignes sélectionnées.
    Je précise que la feuille est protégée par VBA à l'ouverture du fichier.

    En vous remerciant par avance pour vos lumières !
    Cdt

  2. #2
    Membre Expert
    Inscrit en
    Décembre 2002
    Messages
    993
    Détails du profil
    Informations forums :
    Inscription : Décembre 2002
    Messages : 993
    Par défaut
    Bonjour, quelque chose m'interpelle dans ton code. La façon dont tu déclares zone_saisies fait que ce n'est pas une plage de cellules sur laquelle tu peux effectuer des opérations mais une simple chaîne de caractères contenant la valeur texte "e10:ng34".
    Si tu veux la déclarer comme plage de cellules, tu peux faire comme ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    Private Sub Worksheet_SelectionChange(ByVal target As Range)
        Dim zone_saisies As Range
     
        ' Définir la plage spécifiée
        Set zone_saisies = ActiveSheet.Range("e10:ng34")
     
        ' Vérifier si la cellule sélectionnée est dans la plage spécifiée
        If Not Intersect(target, zone_saisies) Is Nothing Then
            ' Appliquer la validation de saisie
            With target.Validation
                .Delete
                .Add Type:=xlValidateInputOnly, AlertStyle:=xlValidAlertStop, Operator:=xlBetween
                .InputMessage = Range("A" & target.Row).Value & Chr(10) & Format(Cells(4, target.Column).Value, "ddd dd mmm")
            End With
        End If
    End Sub

  3. #3
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Janvier 2013
    Messages
    660
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2013
    Messages : 660
    Par défaut
    Bonjour,

    Merci pour ces préconisations que j'ai scrupuleusement appliquées.

    L'erreur apparaît toujours sur la ligne "Add type (...)"

    Le problème peut-il venir de la protection de la feuille ?

    Nota : j'utilise pourtant "userinterfaceonly:=True"

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    For Each wSheet In Worksheets
            wSheet.Visible = True
            wSheet.Protect Password:="toto", userinterfaceonly:=True
        Next wSheet
    Faut-il déverrouiller ponctuellement la protection du Classeur ??

    Cdt

  4. #4
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Janvier 2013
    Messages
    660
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2013
    Messages : 660
    Par défaut
    PS : Je confirme que si je déprotège le classeur, ça fonctionne !!

  5. #5
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Janvier 2013
    Messages
    660
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2013
    Messages : 660
    Par défaut
    Bonsoir,

    Pour être plus précis, c'est manifestement la protection de la feuille qui posait problème (malgré UserInterfaceOnly à True)

    J'ai ajouté une tempo pour l'affichage du message ; a priori, ça fonctionne.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    If Not Intersect(target, zone_saisies) Is Nothing Then
     
            ActiveSheet.Unprotect Password:="toto"
                With target.Validation
                    .Delete
                    .Add Type:=xlValidateInputOnly, AlertStyle:=xlValidAlertStop, Operator:=xlBetween
                    .InputMessage = Range("A" & target.Row).Value & Chr(10) & Format(Cells(4, target.Column).Value, "ddd dd mmm")
                    DoEvents
                    Sleep 1200
                    .Delete
                End With
            ActiveSheet.Protect Password:="toto", userinterfaceonly:=True
        End If
    Et en entête, j'ai ajouté ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    #If VBA7 And Win64 Then
        Private Declare PtrSafe Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)
    #Else
        Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)
    #End If
    Sous réserve de remarques sur l'incohérence de ce code, merci encore pour votre aide,
    Cdt

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 16
    Dernier message: 29/06/2016, 14h11
  2. Réponses: 4
    Dernier message: 06/02/2012, 16h17
  3. Message de validation des données par JSF
    Par rc.dev2009 dans le forum JSF
    Réponses: 6
    Dernier message: 27/07/2011, 17h55
  4. [EXCEL] Validation des données saisies - nouvelle Question :-)
    Par Paloma dans le forum Macros et VBA Excel
    Réponses: 39
    Dernier message: 29/11/2006, 13h28
  5. Réponses: 9
    Dernier message: 17/08/2006, 15h04

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo