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 :

Mot de passe multiutilisateur [XL-2003]


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
    Retraité 72 ans
    Inscrit en
    Mai 2011
    Messages
    244
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Retraité 72 ans

    Informations forums :
    Inscription : Mai 2011
    Messages : 244
    Par défaut Mot de passe multiutilisateur
    Bonjour et mes meilleurs vœux à tous,

    Ne retrouvant pas mon post, j'ai du faire une erreur de forum, je le remet ici.

    Selon le nom (utilisateur) et le mot de passe, donner accès aux feuilles et colonnes selon le schéma indiqué.
    Chaque utilisateur ne doit pouvoir accéder qu'à ces seules feuilles et colonnes sans possibilité pour lui d'afficher les colonnes masquées.
    Que ce soit par : Format, Colonne, Afficher
    Où par sélection des colonnes avant/après.
    Seule la feuille1 doit toujours être visible.
    J'ai trouvé deux codes mais je ne sais pas comment inclure les différentes colonnes dans les codes.
    En vous remerciant.

  2. #2
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 84
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Par défaut
    Bonjour
    Ne retrouvant pas mon post, j'ai du faire une erreur de forum, je le remet ici.
    Ah. Et comment se fait-il que je le retrouve, moi ? --->>
    https://www.developpez.net/forums/d1...e/#post9905152
    Je ne répondrai toutefois ni à l'un, ni à l'autre, puisque pour ce faire, il me faudrait ouvrir ton classeur, ce que je ne ferai JAMAIS.
    A lire (puisque tu ne l'as probablement pas lu) :
    https://www.developpez.net/forums/d8...s-discussions/

  3. #3
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Comme unparia et beaucoup d'utilisateurs de ce forum, je n'ouvre pas les pièces jointes.

    Citation Envoyé par jean30 Voir le message
    Selon le nom (utilisateur) et le mot de passe, donner accès aux feuilles et colonnes selon le schéma indiqué.
    Chaque utilisateur ne doit pouvoir accéder qu'à ces seules feuilles et colonnes sans possibilité pour lui d'afficher les colonnes masquées.
    Que ce soit par : Format, Colonne, Afficher
    Où par sélection des colonnes avant/après.
    Seule la feuille1 doit toujours être visible.
    Faire une protection en VBA est un sujet récurent sur ce forum et les solutions proposées sont généralement très compliquées à mettre en oeuvre et peu fiables.

    Pas besoin de code, il suffit de protéger les feuilles.

    Tu sélectionnes les cellules qui doivent pouvoir être modifiées > Clic droit > Format de cellule > Onglet Protection > Décocher "Verrouillée"
    Tu masques les colonnes ou lignes que tu ne veux pas laisser visibles.
    Tu masques tous les onglets sauf la feuille 1.

    Ensuite, tu poses les protections :
    Ruban Révision > Protéger la feuille > Ne laisse coché que "Sélectionner les cellules déverrouillées" > Eventuellement, mets un mot de passe > Ok
    Ruban Révision > Protéger le classeur > Eventuellement, mets un mot de passe > Ok

  4. #4
    Invité
    Invité(e)
    Par défaut
    bonjour,
    par définition si un utilisateur à réussi à ouvrir une session Windows, c'est qu'il a entré son mot de passe!
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    LogWindows=Environ("Username")

  5. #5
    Membre éclairé
    Homme Profil pro
    Retraité 72 ans
    Inscrit en
    Mai 2011
    Messages
    244
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Retraité 72 ans

    Informations forums :
    Inscription : Mai 2011
    Messages : 244
    Par défaut
    Bonjour,
    J'ai trouvé un code, cependant il pose problème sur la ligne après Else.
    En vous remerciant et en vous présentant tous mes vœux.

    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
    Sub AfficheFeuilles(Utilisateur As String)
    Dim Col As Byte, i As Byte, Lig As Integer
    With Sheets("parametrage") 'dans la feuille paramétrage
    comme on va boucler de la colonne 4 à la dernière colonne, on stocke le n° de la dernière colonne :
        Col = .Cells(1, .Cells.Columns.Count).End(xlToLeft).Column
     'on cherche colonne A le nom d'utilisateur saisi et on stocke son numéro de ligne
        Lig = .Columns(1).Cells.Find(Utilisateur, lookat:=xlWhole).Row
        For i = 3 To Col
            If UCase(.Cells(Lig, i)) = "X" Then     'si on trouve un "X" dans la cellule
                Sheets(.Cells(1, i).Value).Visible = True     'on affiche la feuille   Problème sur cette ligne
            Else
                Sheets(.Cells(1, i).Value).Visible = xlSheetVeryHidden   'sinon on la masque - Problème sur cette ligne
            End If
        Next i
    End With
    End Sub

  6. #6
    Invité
    Invité(e)
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets(.Cells(1, i).Value).Visible =  UCase(.Cells(Lig, i)) = "X" 'on affiche la feuille Problème sur cette ligne Ou pas

  7. #7
    Membre éclairé
    Homme Profil pro
    Retraité 72 ans
    Inscrit en
    Mai 2011
    Messages
    244
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Retraité 72 ans

    Informations forums :
    Inscription : Mai 2011
    Messages : 244
    Par défaut
    Re dysorthographie,
    J'ai toujours le problème.
    Je souhaite afficher les feuilles ou un x figure dans la feuille Paramétrage et masquer les autres xlSheetVeryHidden

  8. #8
    Membre Expert
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 817
    Billets dans le blog
    10
    Par défaut
    Bonjour,

    Pour ne pas tourner en rond pendant 7 ans (au vu du peu que tu nous mets...), j'ai ouvert ton classeur...

    La ligne de code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets(.Cells(1, i).Value).Visible = True
    ou celle-ci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets(.Cells(1, i).Value).Visible = xlVeryHidden
    sous-entend qu'en ligne 1, de la colonne 3 à la dernière colonne utile, tu as inscrit les VERITABLES noms de tes feuilles.

    Or, penses-tu réellement que :
    Feuil
    1
    est équivalant à
    Feuil1

    ............................

  9. #9
    Membre éclairé
    Homme Profil pro
    Retraité 72 ans
    Inscrit en
    Mai 2011
    Messages
    244
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Retraité 72 ans

    Informations forums :
    Inscription : Mai 2011
    Messages : 244
    Par défaut
    Bonjour pijaku,
    Merci de me répondre, mais après correction le problème persiste.
    Code dans Usf :
    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
    Sub AfficheFeuilles(Utilisateur As String)
    Dim Col As Byte, i As Byte, Lig As Integer
    With Sheets("parametrage") 'dans la feuille paramétrage
    'comme on va boucler de la colonne 4 à la dernière colonne, on stocke le n° de la dernière colonne :
        Col = .Cells(1, .Cells.Columns.Count).End(xlToLeft).Column
    'on cherche colonne A le nom d'utilisateur saisi et on stocke son numéro de ligne
        Lig = .Columns(1).Cells.Find(Utilisateur, lookat:=xlWhole).Row
        For i = 3 To Col
            If UCase(.Cells(Lig, i)) = "X" Then     'si on trouve un "X" dans la cellule
                Sheets(.Cells(1, i).Value).Visible = True     'on affiche la feuille
            Else
                Sheets(.Cells(1, i).Value).Visible = xlSheetVeryHidden     'sinon on masque les feuilles dont pas de x dans la feuille Parametrage
            End If
        Next i
    End With
    End Sub
    Le problème se situe entre Else et End If.

  10. #10
    Invité
    Invité(e)
    Par défaut
    1. tu as des retour chariots dans tes titre
      Afficher
      Feuilles
    2. tu commence à la colonne 3 qui n'a pas d'onglet (Afficher Feuilles)


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     For i = 3 To Col
            Sheets(Replace(.Cells(1, i), Chr(10), "")).Visible = UCase(.Cells(Lig, i)) = "X"    'on affiche la feuilleou pas
        Next i

  11. #11
    Membre Expert
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 817
    Billets dans le blog
    10
    Par défaut
    Tant que tu décriras tes ennuis par le mot "problème" en lieu et place du code d'erreur + message d'erreur + ligne bloquante, je m'abstiendrais de répondre...

  12. #12
    Invité
    Invité(e)
    Par défaut
    Pour ma part, je continu de dire qu'il n'y a pas besoin d'un interface login voir poste #4!

  13. #13
    Membre éclairé
    Homme Profil pro
    Retraité 72 ans
    Inscrit en
    Mai 2011
    Messages
    244
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Retraité 72 ans

    Informations forums :
    Inscription : Mai 2011
    Messages : 244
    Par défaut
    Re, dysorthographie, pijaku,
    tu as des retour chariots dans tes titres
    Afficher
    Feuilles
    tu commence à la colonne 3 qui n'a pas d'onglet (Afficher Feuilles)

    Merci de m'avoir ouvert les yeux qui, à mon age, commence à se fatiguer.
    C'est OK

  14. #14
    Invité
    Invité(e)
    Par défaut
    pour information, on ne teste pas un booléen (If UCase(.Cells(Lig, i)) = "X" Then 'si on trouve un "X") pour mettre la même valeur à un autre booléen (Sheets(.Cells(1, i).Value).Visible = True)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets(Replace(.Cells(1, i), Chr(10), "")).Visible = UCase(.Cells(Lig, i)) = "X"
    le If est true ou false!
    Dernière modification par Invité ; 07/10/2018 à 16h16. Motif: Ajout des balises [CODE] et [C]

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

Discussions similaires

  1. [phpMyAdmin] [phpMyAdmin] Problème mot de passe Root !
    Par StouffR dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 7
    Dernier message: 26/09/2014, 11h59
  2. [PostgresSQL]Pb accés des utilisateurs sans mot de passe
    Par woodwai dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 22/05/2003, 16h06
  3. [VB6] [ADO] [Access] Changer le mot de passe
    Par dlpxlid dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 03/03/2003, 09h45
  4. Réccupération du mot de passe d'une connexion
    Par zinaif dans le forum Bases de données
    Réponses: 1
    Dernier message: 02/12/2002, 18h32
  5. Au sujet des mots de passe
    Par FranT dans le forum Langage
    Réponses: 6
    Dernier message: 17/09/2002, 22h16

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