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 :

Aide pour mot de passe


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Septembre 2007
    Messages
    1 896
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Septembre 2007
    Messages : 1 896
    Par défaut Aide pour mot de passe
    Bonjour à toutes et à tous et tous mes voeux pour 2008.

    Voici mon problème. Le code ci-dessous me permet lorsque je clique dans une cellule de faire apparaître un formulaire. Ce que je souhaite faire, c'est qu'au premier click dans une cellule un mot de passe soit demandé, mais uniquement lors du premier click, une fois que le mot de passe ai été renseigné, il ne faut plus que la demande apparaisse.
    Je ne sais pas faire cela, pouvez-vous m'aider ?
    Je vous en remercie par avance

    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
    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    Dim Col As Long
    Dim Lig As Long
    Dim A As Long
        If Intersect(Range("ZO1"), ActiveCell) Is Nothing Then Exit Sub
        If IsEmpty(ActiveCell.Value) Then
    Lig = 5
    Col = ActiveCell.Column
    A = Cells(Lig, Col).Value
        If A = 0 Then Col = Col - 1
        If Weekday(Cells(Lig, Col).Value, 2) < 6 Then
        If IsNumeric(Application.Match(Cells(Lig, Col), Sheets("Don").Range("fériés"), 0)) Then Exit Sub
    Load FrmAbs
    FrmAbs.Show
            End If
        End If
    End Sub

  2. #2
    Expert confirmé
    Avatar de bidou
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mai 2002
    Messages
    3 055
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Transports

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 055
    Par défaut
    tu définis dans ton classeur un nom masqué qui a pour valeur 0. Tu teste cette valeur pour l'affichage du mot de passe.
    lorsque le mot de passe est donné tu le passes à 1
    dans le beforeClose tu le remet à 0

  3. #3
    Membre éprouvé
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Septembre 2007
    Messages
    1 896
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Septembre 2007
    Messages : 1 896
    Par défaut
    Citation Envoyé par bidou Voir le message
    tu définis dans ton classeur un nom masqué qui a pour valeur 0. Tu teste cette valeur pour l'affichage du mot de passe.
    lorsque le mot de passe est donné tu le passes à 1
    dans le beforeClose tu le remet à 0
    Bonjour,

    Excuses moi mais je n'ai rien compris. Tu n'as pas un exemple s'il te plait ?
    Merci

  4. #4
    Membre émérite

    Profil pro
    Inscrit en
    Mai 2007
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 514
    Par défaut
    Bonsoir,

    Excuses moi mais je n'ai rien compris. Tu n'as pas un exemple s'il te plait ?
    Le principe proposé par Bidou consiste à stocker une valeur indiquant si le mot de passe a déja été demandé, puis à tester cette valeur afin d'éviter d'afficher la demande systématiquement. Bidou propose d'utiliser un nom, tu peux aussi utiliser une variable locale à la procédure:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
        Static Pw As Boolean
        If Not Pw Then
            'Demande du mot de passe
            Pw = True 'Si le mot de passe est correct, sinon sortir de la procedure
        End If
        'Traitement
    End Sub
    Cordialement,

    Tirex28/

  5. #5
    Membre chevronné
    Profil pro
    Inscrit en
    Février 2007
    Messages
    491
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 491
    Par défaut
    bonjour,

    tu peux utiliser un inputbox pour ceci

    tu définis dans ton classeur un nom masqué qui a pour valeur 0. Tu teste cette valeur pour l'affichage du mot de passe.
    lorsque le mot de passe est donné tu le passes à 1
    dans le beforeClose tu le remet à 0
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    dim valid_motpas as boolean
    valid_motpas = false
    motdepasse = inputbox("rentrer votre mot de passe")
    if motdepasse = "mot ...." then 
    valid_motpas = true
    ou mieux encore utiliser la boite de dialogue "mot de passe" (je ne connais pas le nom)

  6. #6
    Membre éprouvé
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Septembre 2007
    Messages
    1 896
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Septembre 2007
    Messages : 1 896
    Par défaut
    Citation Envoyé par patbou Voir le message
    bonjour,

    tu peux utiliser un inputbox pour ceci


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    dim valid_motpas as boolean
    valid_motpas = false
    motdepasse = inputbox("rentrer votre mot de passe")
    if motdepasse = "mot ...." then 
    valid_motpas = true
    ou mieux encore utiliser la boite de dialogue "mot de passe" (je ne connais pas le nom)
    Bonjour,
    Je ne sais pas si c'est le lendemain des fêtes, mais je ne comprends toujours pas.
    Où dois-je mettre le code ? ainsi que le nom masqué qui a pour valeur 0 ?
    C'est la brasse coulée. Désolé

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

Discussions similaires

  1. [MySQL] Aide : préfixe pour mot de passe MD5
    Par RobinEF dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 08/11/2012, 08h19
  2. Besoin d'aide pour mot de passe
    Par bil_home dans le forum IHM
    Réponses: 3
    Dernier message: 28/05/2010, 10h17
  3. connection pour mot de passe
    Par itak33 dans le forum WebDev
    Réponses: 1
    Dernier message: 08/06/2007, 15h36
  4. [MySQL] problème envoi mail pour mot de passe
    Par bonsam dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 17/11/2006, 20h57
  5. utilisation Edit pour mot de passe
    Par devlopassion dans le forum C++Builder
    Réponses: 5
    Dernier message: 11/10/2006, 10h37

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