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 :

Autoriser sélection d'une plage de cellule dans une feuille Excel


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    39
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 39
    Points : 31
    Points
    31
    Par défaut Autoriser sélection d'une plage de cellule dans une feuille Excel
    Bonjour à tous

    Question : peut-on -avec le langage VBA- autoriser la sélection d'une plage de cellule pendant l'éxécution du code ?

    Exemple : dans le déroulement du programme, l'utilisateur ne pourra sélectionner qu'une ou plusieurs cellules dans la plage A1 à A10. Il ne pourra sélectionner la cellule B1 par exemple.

    Merci pour votre réponse précieuse

  2. #2
    Expert éminent
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Points : 6 781
    Points
    6 781
    Par défaut
    Hello,

    tu peux intercepter les sélections utilisateurs :
    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
    19
    20
    21
    22
    Const r As String = "A1:A10"
    Dim SelectOk As String
     
    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
     
    Application.EnableEvents = False
     
    If Intersect(Target, Range(r)) Is Nothing Then
        Range(SelectOk).Select
        SelectOk = Selection.Address
    Else
        If Intersect(Target, Range(r)).Address <> Target.Address Then
            Range(SelectOk).Select
            SelectOk = Selection.Address
        Else
            SelectOk = Target.Address
        End If
    End If
     
    Application.EnableEvents = True
     
    End Sub

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    39
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 39
    Points : 31
    Points
    31
    Par défaut
    Merci pour cette réponse :

    Comment utiliser le code ?
    Je déclare les variables (Const r As String = "A1:A10"
    Dim SelectOk As String) dans le programme principal et je fais appel au programme Worksheet_SelectionChange dans le code ? Cela ne fonctionne pas. (Je débute)

    Précision sur la question :

    Je souhaite par exemple obliger l'utilisateur à sélectionner une ou plusieurs cellules dans la plage A1:A10 dans le petit programme qui suit.
    Autrement dit, on peut imaginer ne rendre actif -que pour la procédure associée à un bouton- une certaine plage A1:A10. Exemple de code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub CmdValider_Click()
     
    'ajouter code pour vérifier que l'utilisateur soit bien dans la plage A1:A10
    Selection.FormulaR1C1 = "2"
     
    End sub
    Un grand merci

  4. #4
    Expert éminent
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Points : 6 781
    Points
    6 781
    Par défaut
    il faut mettre ce code dans le module de la feuille sur laquelle tu veux faire ces limitations.
    un copier / coller suffira.

  5. #5
    lvr
    lvr est déconnecté
    Membre extrêmement actif Avatar de lvr
    Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2006
    Messages
    910
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Avril 2006
    Messages : 910
    Points : 1 365
    Points
    1 365
    Par défaut
    Je ne suis pas sur que ta macro puisse s'interrompre pour permettre à l'utilisateur de sélectionner une cellule.

    Il faudra impérativement qu'il en sélectionne une *avant* qu'il lance la macro.

    Cafeine: comment (et quand) est-ce que tu initialise ta variable SelectOk ?

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    39
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 39
    Points : 31
    Points
    31
    Par défaut
    Merci à tous,

    J'ai finalement opté pour une autre solution.

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 17/03/2014, 21h17
  2. [XL-2007] InputBox pour sélectionner cellule ou une plage de cellules dans une feuille.
    Par Nonno 94 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 14/02/2014, 19h01
  3. [XL-2003] Sélection d'une cellule dans une plage de cellule
    Par amelyfred dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 24/03/2011, 16h47
  4. Trouver une plage de cellule dans une autre plage
    Par ouskel'n'or dans le forum Contribuez
    Réponses: 0
    Dernier message: 16/04/2008, 14h27

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