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 :

[VBA-E] (débutante) comment interdire l'accès à une plage?


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 2
    Points : 1
    Points
    1
    Par défaut [VBA-E] (débutante) comment interdire l'accès à une plage?
    Bonjour!

    quelqu'un peut-il m'aider, je suis débutante...

    1- je dois créer une procédure qui affiche un message dès que utilisateur selectionne une plage déterminée dont on souhaite interdire l'accès, puis qui déplace le curseur sur la cellule A1 de la feuille.
    Voici exactement ce que j'ai écrit:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub Question3() 
    Private Sub Worksheet_SelectionChange(ByVal Target As Range) 
      If Not Application.Intersect(Target, Range("A1:B3")) Is Nothing Then 
        MsgBox "vous ne pouvez pas selectionner cette plage!" 
        Range("A1:B3").Select 
      End If 
    End Sub
    Mais ça ne marche pas...


    2- comment créer une fonction qui calcule la moyenne des valeurs, contenues dans une plage de valeurs selectionnées, en ne retenant que les valeurs de la plage comprises entre 2 bornes variables.

    Merci et reconnaissance éternelle à tout génie de l'informatique qui pourra m'aider...

  2. #2
    Expert confirmé
    Avatar de zazaraignée
    Profil pro
    Étudiant
    Inscrit en
    Février 2004
    Messages
    3 174
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2004
    Messages : 3 174
    Points : 4 085
    Points
    4 085
    Par défaut
    Salut

    C'est une fonction d'Excel. Tu n'as pas besoin de passer par le code VBA. Par défaut, les cellules d'une feuille sont verrouillée. Alors si tu mets une protection sur ta feuille, toutes les cellules sont non-modifiables.

    Sélectionne toutes les plages où l'utilisateur aura l'autorisation d'entrer des données. Ensuite, affiche la boîte de dialogue Format de cellule et clique sur l'onglet Protection et décoche la (flèche? nonnn...) case Verrouillé.

    Finalement, va dans le menu Outils (il me semble) et sélectionne Protection > Feuille. Une boîte de dialogue te demande d'entrer un mot de passe. C'est mieux d'en mettre un et note-le dans ta documentation de projet.

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 2
    Points : 1
    Points
    1
    Par défaut VBA comment interdire accès à une plage
    oui merci zaaraigné!
    le problème c'est que je dois ECRIRE cette procédure en langage VBA (parce que sinon, moi aussi je sais me servir des options d'Excel...), sinon en effet ça serait du niveau maternelle...
    des idées?

  4. #4
    Membre expert
    Avatar de Igloobel
    Homme Profil pro
    Développeur ERP - VBA et Formateur bureautique
    Inscrit en
    Septembre 2005
    Messages
    1 869
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Développeur ERP - VBA et Formateur bureautique
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 869
    Points : 3 442
    Points
    3 442
    Billets dans le blog
    1
    Par défaut
    Salut

    Et si tu demande à Excel de faire la macro à ta place ça marche pas ?
    ( tu sais dans: Outils - macros - nouvelles macro, etc ...)

    Tu dis

    Igloobel

  5. #5
    Modérateur
    Avatar de AlainTech
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mai 2005
    Messages
    4 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2005
    Messages : 4 235
    Points : 24 327
    Points
    24 327
    Par défaut Re: [VBA-E] (débutante) comment interdire l'accès à une plag
    Citation Envoyé par aniu
    1- je dois créer une procédure qui affiche un message dès que utilisateur selectionne une plage déterminée dont on souhaite interdire l'accès, puis qui déplace le curseur sur la cellule A1 de la feuille.
    Voici exactement ce que j'ai écrit:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub Question3() 
    Private Sub Worksheet_SelectionChange(ByVal Target As Range) 
      If Not Application.Intersect(Target, Range("A1:B3")) Is Nothing Then 
        MsgBox "vous ne pouvez pas selectionner cette plage!" 
        Range("A1:B3").Select 
      End If 
    End Sub
    Mais ça ne marche pas...
    Quelle est la plage à laquelle tu veux empêcher l'accès?

    Dans ton code, tu interdis Range([A1],[B3]) puis tu sélectionnes cette même plage...

    Peut-être cherches-tu à n'autoriser que Range([A1],[B3])...

    Si c'est le cas, il y a un Not de trop:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If Application.Intersect(Target, Range("A1:B3")) Is Nothing Then

Discussions similaires

  1. [2005] Comment interdire l'accès à la définition d'une table?
    Par titwawa dans le forum Développement
    Réponses: 1
    Dernier message: 11/03/2014, 10h36
  2. comment interdire l'accés à mon systéme Win 98
    Par ghita269 dans le forum Windows 2000/Me/98/95
    Réponses: 15
    Dernier message: 20/10/2007, 23h34
  3. Réponses: 4
    Dernier message: 28/09/2006, 13h37
  4. Comment interdire l'acces a internet à un processus ?
    Par programmerPhil dans le forum Sécurité
    Réponses: 3
    Dernier message: 05/04/2006, 01h15
  5. Interdire l'acces à une Jframe "mere" ?
    Par pierre.zelb dans le forum Agents de placement/Fenêtres
    Réponses: 6
    Dernier message: 20/06/2005, 13h29

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