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 :

Comment exécuter une seule fois un IF ? [XL-2013]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2018
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2018
    Messages : 7
    Par défaut Comment exécuter une seule fois un IF ?
    Bonjour à tous,

    Je viens d'éditer une macro, qui a pour but de copier la date de la cellule B5 dans B8 si la valeur de la cellule E5 est >1
    Le problème est qu'elle s'exécute en boucle est finie par planter...

    Savez vous comment faire pour que la macro ne s'exécute, qu'une seule fois, à chaque changement de valeur dans E5 ?


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Private Sub Worksheet_Change(ByVal Target As Range)
     
    If [E5] > 1 Then
    Range("B5").Select
        Selection.Copy
        Range("B8").Select
        Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
            :=False, Transpose:=False
        Application.CutCopyMode = False
        Selection.NumberFormat = "dd/mm/yyyy hh:mm:ss"
        End If
        End Sub

  2. #2
    Expert confirmé Avatar de BENNASR
    Homme Profil pro
    Responsable comptable & financier
    Inscrit en
    Décembre 2013
    Messages
    2 974
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Responsable comptable & financier
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2013
    Messages : 2 974
    Par défaut
    bonjour
    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)
    Range("B8").Value = ""
    If Range("E5").Value > 0 Then
    Range("B8").Value = Range("B5").Value
    End If
    Range("B8").NumberFormat = "dd/mm/yyyy hh:mm:ss"
    End Sub

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2018
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2018
    Messages : 7
    Par défaut
    Merci de ta réponse

    Cependant, le problème s'est déplacé du coup...

    Je faisais un collage spécial car j'ai besoin de figer la date: la date de la cellule B5 et la valeur de E5 sont en fait extrait de signaux de régulation.
    J'ai besoin de capturer la date au moment où le bit lu sur E5 monte à 1.
    Avec le code que tu proposes la date s'actualise tant que le bit est à 1.

  4. #4
    Expert confirmé
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juillet 2014
    Messages
    2 682
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aude (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2014
    Messages : 2 682
    Par défaut
    Bonjour,

    Citation Envoyé par Samycool Voir le message
    Savez vous comment faire pour que la macro ne s'exécute, qu'une seule fois, à chaque changement de valeur dans E5 ?
    Si ce n'est pas déjà fait je t'invite à lire ce tuto sur les évènement: https://silkyroad.developpez.com/VBA...Feuille/#LII-E

    Tu utilise une macro évènementielle qui se déclenche a chaque modification de ta feuille et cette macro modifie la feuille donc se déclenche elle-même d'où la boucle infinie. Pour résoudre ce problème tu dois désactiver les macros évènementielles pendant l'exécution de cette macro et les réactiver ensuite grâce à la commande "application.enableevents = false / true"
    Pour ne la déclencher qu'au changement de valeur dans la cellule E5 il suffit d'utiliser le paramètre Target de cet évènement:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    If Target.Address = Range("E5").Address Then
     'ton code
    end if

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2018
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2018
    Messages : 7
    Par défaut
    Merci de ton conseil

    Au final je me suis débrouillé autrement en comparant l'état du bit à la seconde n-1 avec la seconde n, pour capturer la date au moment où il passe à 1.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    If Range("F3").Value > Range("F2").Value Then
    Range("B8").Value = Range("B5").Value
    End If
    End Sub

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

Discussions similaires

  1. Comment exécuter une seule fois
    Par pixelrock dans le forum Eclipse Platform
    Réponses: 2
    Dernier message: 30/11/2009, 10h39
  2. [MySQL] Comment afficher une seul fois un field s'il apparait dans plusieurs enregistrements
    Par pierrot10 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 21/05/2009, 16h11
  3. lu tous les jours mais exécuté une seule fois par mois
    Par sianto dans le forum Scripts/Batch
    Réponses: 13
    Dernier message: 17/11/2008, 09h08
  4. Réponses: 6
    Dernier message: 22/05/2008, 23h15
  5. Réponses: 7
    Dernier message: 25/07/2007, 13h14

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