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 :

désactiver momentanément détection de selection


Sujet :

Macros et VBA Excel

  1. #1
    Membre confirmé Avatar de Oh!Tofocus
    Profil pro
    Inscrit en
    Août 2007
    Messages
    217
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 217
    Par défaut désactiver momentanément détection de selection
    Saluts à tous
    J'ai un déction de changement de sélection dans une feuille.
    Mais dans la macro associée a cette détection je voudrais pouvoir faire une selection sans que ma routine ne le détecte.
    Si non elle s'emballe et tourne en rond

    comment désactiver la détection pendant l'execution de ma macro ?

    voici un exemple simplifié de macro qui s'emballe:
    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)
     
    ' selectionne la case a droite de la case sélectionnée
     
    Cells(target.Row, target.Column + 1).Select
     
    End Sub

  2. #2
    Expert confirmé

    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    3 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 3 317
    Par défaut
    bonsoir


    Tu peux utiliser la propriété EnableEvents.

    http://silkyroad.developpez.com/VBA/EvenementsFeuille/


    ps
    est ce que tu es vraiment obligé d'utiliser le .Select ?


    bonne soirée
    michel

  3. #3
    Membre confirmé Avatar de Oh!Tofocus
    Profil pro
    Inscrit en
    Août 2007
    Messages
    217
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 217
    Par défaut
    Merci beaucoup pour cette réponse rapide ça marche impec

    Citation Envoyé par SilkyRoad
    est ce que tu es vraiment obligé d'utiliser le .Select ?
    oui car je l'utilise pour afficher ou effacer une croix dans une case en faisant un click dessus.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    Application.EnableEvents = False
     
    If Target.Value = "x" Then
    Target.Value = " "
    Else
    Target.Value = "x"
    End If
    'déplace la selection pour pouvoir effacer la croix si necessaire
    Cells(Target.Row, Target.Column + 1).Select
     
    Application.EnableEvents = True
    End Sub

    par contre je voudrais détecter si target est sur une colonne déterminée mais je n'arrive pas à utiliser Intersect avec target et range("C:C")
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    test = Intersect(Range("C:C"), Range(Target.Address))
    If test Is Nothing Then
    '.....
    '....
    ça plante à test =....

  4. #4
    Membre confirmé Avatar de Oh!Tofocus
    Profil pro
    Inscrit en
    Août 2007
    Messages
    217
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 217
    Par défaut
    Mais peut être y a t il plus simple pour basculer d'interieurs d'une case d'un simple clic de souris dessus ?

  5. #5
    Membre confirmé Avatar de Oh!Tofocus
    Profil pro
    Inscrit en
    Août 2007
    Messages
    217
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 217
    Par défaut
    A propos du test de colonne
    je viens de trouver ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    'execute uniquement si target est dans la colonne C:C (3)
    If Target.Column = 3 Then
    '....
    '....
    endif
    mais ça ne résoud pas mon incomprehension pour Intersect

  6. #6
    Expert confirmé

    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    3 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 3 317
    Par défaut
    rebonsoir


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
        Dim Test As Range
        Set Test = Intersect(Columns("C:C"), Target)
     
        If Not Test Is Nothing Then MsgBox "Ok"
    End Sub

    michel

  7. #7
    Membre confirmé Avatar de Oh!Tofocus
    Profil pro
    Inscrit en
    Août 2007
    Messages
    217
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 217
    Par défaut
    EXTRA !!!!

    Merci beaucoup pour ce coup de main

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

Discussions similaires

  1. désactiver "le cadre de selection" sous FF
    Par Death83 dans le forum Mise en page CSS
    Réponses: 5
    Dernier message: 20/12/2006, 09h23
  2. Désactiver momentanément le changement d'enregistrement
    Par mastasushi dans le forum Access
    Réponses: 5
    Dernier message: 15/05/2006, 10h09
  3. Désactivation et détection de clic sur bouton radio
    Par Prue dans le forum Général JavaScript
    Réponses: 19
    Dernier message: 21/04/2006, 13h50
  4. [HTML][Select]désactiver une option sous IE ?
    Par tiPouick dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 05/11/2004, 12h13

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