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 :

Ôter protection feuille lors d'un changement d'état d'une liste déroulante [XL-2010]


Sujet :

Macros et VBA Excel

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Automaticien
    Inscrit en
    Juin 2014
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Automaticien

    Informations forums :
    Inscription : Juin 2014
    Messages : 6
    Points : 5
    Points
    5
    Par défaut Ôter protection feuille lors d'un changement d'état d'une liste déroulante
    Bonjour à tous et à toute,

    Après plusieurs tentatives, et plusieurs solutions trouvées sur Internet et notamment sur votre site, je n'ai pas réussis à trouver une réponse qui marche dans mon cas.

    Voici le contexte :
    Je développe un fichier Excel qui ne pourra être modifiable dans l'avenir, j'ai donc dans toute mes macros (non-joint car trop lourde) une simple fonction "Unprotect" au début et "Protect" à la fin des macros.

    Cependant, j'utilise une liste de type déroulante avec plusieurs champs définis par plage (attention, pas un Userform, je parle bien d'une liste déroulante placée sur la feuille Excel) et j'associe donc à cette liste une case (par exemple A1) qui écrit une valeur numérique (1,2,3,4 etc...).
    Evidemment, une erreur "Document protégé" apparaît lorsque je souhaite simplement changer le champ de cette liste car elle écrit au même moment sur "A1".

    Ma question est simple : Est-il possible d’exécuter une macro (ou autre solution) permettant d'ôter la protection lorsque la personne a choisi une nouvelle valeur de la liste déroulante, puis après avoir automatiquement changé la valeur numérique de la case "A1", remettre la protection de la feuille ?

    J'espère avoir été assez clair dans mes explications, je suis disponible pour toute autre questions.

    Merci d'avance,

    ZowZow.

  2. #2
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juin 2014
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2014
    Messages : 25
    Points : 29
    Points
    29
    Par défaut
    Salut ZowZow,

    Au vu de la description du problème, je déduis que ta liste déroulante est un controle de formulaire et non un controle ActiveX (il y a deux catégorie quand tu cliques sur Inserer).
    D'après ce que je sais, ce type de contrôle n'offre pas beaucoup de fonctionnalité et je ne pense pas qu'on puisse faire ce que tu veux avec.
    Par contre avec un controle ActiveX c'est possible. Si tu ajoutes une telle liste déroulante à ta feuille, tu auras accès à plusieurs évènements dont un qui se lance lors du choix d'un élément de la liste. Il suffit alors de lancer ta macro Unprotect puis tu édites la cellule à laquelle était lié ton ancienne liste déroulante.

    Pour accéder à ces évènements tu vas dans l'éditeur vba, dans le code de la feuille où tu as mis ton contrôle. En haut il y aura deux listes, dans (général) tu choisis ta liste (combobox) et dans (Déclaration) tu choisis l'évènement (change dans ton cas).

    Je suis pas sur d'avoir été clair donc hésite pas à revenir

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Automaticien
    Inscrit en
    Juin 2014
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Automaticien

    Informations forums :
    Inscription : Juin 2014
    Messages : 6
    Points : 5
    Points
    5
    Par défaut
    Bonjour,

    Tout d'abord merci Ptitcool pour cette réponse claire et rapide.

    Cependant après avoir essayé, cela ne résout pas vraiment le problème, en effet le combobox "écrit" d'abord dans "A1" avant d’exécuter le code "Combobox_Change".
    Du coup l'erreur apparaît toujours, et la protection est ôtée après avoir cliqué sur le "ok" d'erreur.
    Je ne sais pas si je suis très clair..

    Je pense donc que la solution serait de ne pas associer une case (ici A1) à la liste déroulante, et d'utiliser directement la fonction "Combobox_Change" pour exécuter un programme qui récupère la valeur de Combobox, de cette manière le droit en lecture seule ne posera pas de problème.

    Je vais essayer plusieurs méthode et je ferrais un double post en collant mon bout de programme si cela fonctionne.

    Je suis toujours preneur d'autres solutions qui résoudraient mon problème,

    ZowZow.

  4. #4
    Futur Membre du Club
    Homme Profil pro
    Automaticien
    Inscrit en
    Juin 2014
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Automaticien

    Informations forums :
    Inscription : Juin 2014
    Messages : 6
    Points : 5
    Points
    5
    Par défaut
    Je m'excuse du double post mais j'ai trouvé la solution à mon problème.

    Il fallait tout simplement ne pas associer de case à la Combobox, et le faire "manuellement" en VB.

    Voici donc le code très simple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Private Sub ComboBox1_Change()
     
    Sheets("Ma_Feuille").Unprotect Password:="Mon_Mot_De_Passe"
     
    Dim Valeur As String
     
    Valeur = ComboBox1.Value
    Range("A1").Value = Valeur
     
    Sheets("Ma_Feuille").Protect Password:="Mon_Mot_De_Passe"
     
    End Sub
    Je passe le sujet en [RESOLU], merci pour l'aide !

    ZowZow.

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

Discussions similaires

  1. [XL-2010] Envoi mail automatique avec une macro lors d'un changement d'état d'une cellule
    Par sly77400 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 12/03/2015, 20h00
  2. [XL-2010] Exécution macro lors d'un changement de valeur dans une cellule
    Par yoyo3d dans le forum Macros et VBA Excel
    Réponses: 17
    Dernier message: 27/01/2015, 20h06
  3. Que faire des index lors d'un changement de type d'une colonne ?
    Par Kropernic dans le forum Administration
    Réponses: 2
    Dernier message: 12/12/2012, 11h24
  4. [AC-2007] changement de source dans une liste déroulante
    Par franckimmo dans le forum VBA Access
    Réponses: 4
    Dernier message: 28/01/2010, 11h25
  5. Réponses: 1
    Dernier message: 29/09/2005, 11h10

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