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 :

Fixer une variable dans une boucle


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2017
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2017
    Messages : 1
    Par défaut Fixer une variable dans une boucle
    Bonjour à tous !

    J'ai un soucis avec l'une de mes macros vba, et n'étant pas trop trop un pro, je recquiers votre assistance. D'abord le contexte, puis le code, puis le soucis.
    Mon document est un suivi d'une machine minute par minute et le but est, de façon automatisée, de déterminer le temps de démarrage nommé Date2. Cela correspond au temps entre le moment où la vis commence à tourner (valeur dans la colonne E > 300 nommé Date1) et le moment où le second moteur se met en marche (valeur dans la colonne G > 1000). La colonne A correspond à la date et la B au numéro du produit.

    Le code maintenant :
    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
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    Sub TpsDemarrage()
     
    FinLigne = 9602
    NumeroLigne = 2
     
    Dim boolean1 As Boolean
    boolean1 = False
    Dim boolean2 As Boolean
    boolean2 = False
    Dim boolean3 As Boolean
    boolean3 = False
    Dim boolean4 As Boolean
    boolean4 = False
     
    Dim Date1 As Date
    Dim Date2 As Date
     
    While boolean1 = False
        If NumeroLigne > FinLigne Then boolean1 = True
        If Range("E" & NumeroLigne).Value > 300 And Range("G" & NumeroLigne).Value < 1000 And boolean2 = False Then Date1 = Range("A" & NumeroLigne).Value And boolean2 = True
        'Etape1 Démarrage
        If Range("E" & NumeroLigne).Value > 300 And Range("G" & NumeroLigne).Value > 1000 And boolean3 = False Then Date2 = Range("A" & NumeroLigne).Value - Date1 And boolean3 = True
        'Temps entre l'étape1 et la fin du démarrage
        If Range("G" & NumeroLigne).Value > 1000 And Range("G" & NumeroLigne - 1).Value < 1000 Then Range("AR" & NumeroLigne).Value = Date2
        'Mettre le temps de démarrage à la fin du démarrage
        If Range("B" & NumeroLigne).Value <> Range("B" & NumeroLigne + 1).Value Then boolean4 = True
        'Si on change de produit
        If boolean4 = True Then Date1 = 0 And Date2 = 0 And boolean2 = boolean3 = boolean4 = False
        'Alors on réinitialise tout et on ontinue pour le produit suivant
        NumeroLigne = NumeroLigne + 1
    Wend
     
    End Sub
    Le soucis :
    A la ligne 19, j'ai mal exprimé ma variable Date1 et je ne parviens pas à la fixer. Dans ce cas, j'obtiens toujours Date2 = 00:00:00 car Date1 n'est pas fixe.

    Si vous avez un quelconque axe d'amélioration envisageable je suis preneur !
    Merci beaucoup pour votre aide (ou au moins d'avoir lu)

  2. #2
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 84
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Par défaut
    Bonjour

    et n'étant pas trop trop un pro
    est un euphémisme.
    Cette seule ligne de code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If boolean4 = True Then Date1 = 0 And date2 = 0 And boolean2 = boolean3 = boolean4 = False
    Met de manière évidente en exergue que tu ne t'es même pas encore intéressé aux rudiments de VBA.
    Cette ligne de code n'a aucun sens.
    Désolé, mais je me sauve à toutes jambes, dans de tels cas.
    On ne met jamais la charrue avant les boeufs.

Discussions similaires

  1. Réponses: 3
    Dernier message: 09/03/2016, 16h23
  2. portée d'une variable dans une fonction dans une méthode
    Par laurentg2003 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 29/06/2009, 19h05
  3. Réponses: 4
    Dernier message: 29/01/2008, 11h12
  4. Réponses: 1
    Dernier message: 15/02/2007, 00h24
  5. Mettre une valeur d'une table dans une variable
    Par Raphou96 dans le forum Access
    Réponses: 5
    Dernier message: 06/02/2006, 15h19

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