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 :

Application OnTime


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
    Superviseur de production
    Inscrit en
    Mai 2017
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Canada

    Informations professionnelles :
    Activité : Superviseur de production
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2017
    Messages : 2
    Par défaut Application OnTime
    Bonjour aux dieux du VBA !

    Je suis à bout de ressources...

    J'ai un fichier Excel qui comporte des macros de copier/coller les valeurs d'une colonne où les données sont rafraichies à toutes les 10 minutes. En tout, 15 boutons à lesquels sont associés 15 macros identiques mise à part l'endroit où coller les valeurs que je dois exécuter manuellement.
    Exemple:

    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
    Sub ab()
    '
    ' ab Macro
    '
    
    '
        Range("AH39").Select
        ActiveCell.FormulaR1C1 = ""
        Range("AF39:AF56").Select
        Selection.Copy
        Range("AH39").Select
        Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
            :=False, Transpose:=False
    End Sub
    
    
    
    Sub ac()
    '
    ' ac Macro
    '
    
    '
        Range("AI39").Select
        ActiveCell.FormulaR1C1 = ""
        Range("AF39:AF56").Select
        Application.CutCopyMode = False
        Selection.Copy
        Range("AI39").Select
        Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
            :=False, Transpose:=False
    End Sub
    Et ainsi de suite jusqu'à la macro ao, jusque-là, assez simple !

    Mais je cherche à les faire exécuter une à la suite de l'autre avec un intervalle de 45 minutes entre chaque macro par l'application OnTime à l'ouverture du fichier.

    Exemple:
    Ouverture du fichier à 7:00
    Exécution de la macro aa à l'ouverture du fichier
    Exécution de la macro ab 45 minutes plus tard (7:45)
    Exécution de la macro ac 45 minutes plus tard (8:30)


    Probablement un problème simple à régler pour la plupart des gens ici, mais comme mes connaissances en la matière sont vraiment nulles, j'ai beau chercher, je suis incapable de trouver des réponses à mon problème.

    Merci de votre aide !

  2. #2
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 682
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 682
    Par défaut
    Bonjour,

    bien que le temps de traitement sois infime dans la plupart de tes macros, tu souhaites exactement
    - lancer 45 minutes apres la fin du traitement d'une macro la macro suivante ?
    ou
    - lancer a 7h00 / 7h45 / 8h30 / etc. ?

    Ici si tu utilises Application.OnTime, cela signifiera que le fichier reste ouvert. Est-ce bien ce que tu souhaites ?
    Tu peux egalement passer par le planificateur de taches Windows
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Migrer les applications VBA Access et VBA Excel vers la Power Platform
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Coffrets disponibles de mes ouvrages : https://www.editions-eni.fr/jean-philippe-andre
    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  3. #3
    Nouveau candidat au Club
    Homme Profil pro
    Superviseur de production
    Inscrit en
    Mai 2017
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Canada

    Informations professionnelles :
    Activité : Superviseur de production
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2017
    Messages : 2
    Par défaut
    Bonjour Jean-Philippe André,

    Effectivement, je souhaite que, après 45 minutes, la macro suivante soit exécutée. Mes fichiers restent également ouverts.

    Merci

  4. #4
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 682
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 682
    Par défaut
    Dans ce cas, la syntaxe generale est la suivante

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.OnTime HeureDeLancement, MacroALancer
    soit par exemple

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.OnTime Now + TimeValue("00:45:00"), "ac"
    qui lancera la macro ac dans 45 minutes a partir de maintenant =]
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Migrer les applications VBA Access et VBA Excel vers la Power Platform
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Coffrets disponibles de mes ouvrages : https://www.editions-eni.fr/jean-philippe-andre
    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  5. #5
    Membre Expert
    Profil pro
    Inscrit en
    Février 2007
    Messages
    2 266
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 2 266
    Par défaut
    Bonjour,

    comme tu décales ton collage d'une colonne à chaque fois, appelle toutes les 45' la même macro où tu gères ce décalage selon le n° d'appel :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub coller()
        Static col As Long ' = 0 à l'ouverture
        Range("AF39:AF56").Copy
        Range("AH39").Offset(col).PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
            :=False, Transpose:=False
        Application.CutCopyMode = False
        col = col + 1
    End Sub
    eric

Discussions similaires

  1. Paramètres avec Application.OnTime
    Par ouskel'n'or dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 07/11/2007, 17h50
  2. Problème avec Application.OnTime
    Par Uopip dans le forum VBA Outlook
    Réponses: 14
    Dernier message: 09/07/2007, 15h14
  3. Adaptation de Application.OnTime
    Par adidas40 dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 27/09/2006, 15h13
  4. L'événement Application.OnTime Sous VBA
    Par SubObjectif dans le forum Access
    Réponses: 14
    Dernier message: 04/08/2006, 12h00
  5. [VBA-E] Comment annuler un appel planifié avec Application.OnTime ?
    Par Efpoint dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 30/05/2006, 14h24

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