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 :

[Processus] Garder le contrôle sur un userform


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de Commodore
    Homme Profil pro
    Business manager
    Inscrit en
    Février 2004
    Messages
    599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Business manager

    Informations forums :
    Inscription : Février 2004
    Messages : 599
    Par défaut [Processus] Garder le contrôle sur un userform
    Bonjour,

    Quand on exécute un traitement long à partir d'un bouton placé sur un UserForm, on perd le controle pendant la durée d'éxécution de la macro.

    Je cherche comment faire pour garder le contrôle sur le form sans pour autant interrompre la macro en cours...

    J'ai pensé à faire l'équivalent d'un fork() en C mais je ne sais absolument pas comment m'y prendre ni si c'est la méthode la plus simple ni si c'est possible.

    Quelqu'un pourrait-il m'apporter des éléments de réponse svp ?

    Psy

  2. #2
    Membre chevronné

    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    453
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 453
    Par défaut
    Si c'esl long, c'est probablement que tu fais une longue boucle quelconque.

    Tu peux insérer un DoEvents dans la boucle.

    Par contre, c'est dangereux de faire ça car si l'utilisateur redémarre le processus en cliquant sur un contrôle, la chaîne des processus risque de planter.

  3. #3
    Membre éprouvé Avatar de Commodore
    Homme Profil pro
    Business manager
    Inscrit en
    Février 2004
    Messages
    599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Business manager

    Informations forums :
    Inscription : Février 2004
    Messages : 599
    Par défaut
    le but est de pouvoir lancer plusieurs macros en même temps...

    pas de planter la chaine de processus

  4. #4
    Membre éprouvé Avatar de Commodore
    Homme Profil pro
    Business manager
    Inscrit en
    Février 2004
    Messages
    599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Business manager

    Informations forums :
    Inscription : Février 2004
    Messages : 599
    Par défaut
    personne ne peut me répondre ?

  5. #5
    Membre chevronné

    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    453
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 453
    Par défaut
    Je t'ai répondu déjà... DoEvents

  6. #6
    Membre éprouvé Avatar de Commodore
    Homme Profil pro
    Business manager
    Inscrit en
    Février 2004
    Messages
    599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Business manager

    Informations forums :
    Inscription : Février 2004
    Messages : 599
    Par défaut
    je le place où le DoEvents alors ?
    voila du concret:

    je souhaite garder la main pour pouvoir lancer une autre macro en même temps que ce code s'éxécute:
    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
        i = 2
        Do While Not table.EOF
            With Workbooks(NomFich).Worksheets("Feuil1")
                .Range("A" & i) = table.Fields(0).Value
                .Range("B" & i) = table.Fields(1).Value
                .Range("C" & i) = table.Fields(2).Value
                .Range("D" & i) = table.Fields(3).Value
                .Range("E" & i) = table.Fields(4).Value
                .Range("F" & i) = table.Fields(5).Value
                .Range("G" & i) = table.Fields(6).Value
                .Range("H" & i) = table.Fields(7).Value
                .Range("I" & i) = table.Fields(8).Value
                .Range("J" & i) = table.Fields(9).Value
                .Range("K" & i) = table.Fields(10).Value
                table.MoveNext
                i = i + 1
            End With
        Loop

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

Discussions similaires

  1. Réponses: 21
    Dernier message: 24/06/2014, 12h28
  2. Bouger des contrôles sur un userform
    Par fxleo dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 03/06/2013, 16h51
  3. Réponses: 10
    Dernier message: 21/03/2013, 13h54
  4. Intercepter un click sur un Contrôle dans une UserForm
    Par RedColibri dans le forum VBA Word
    Réponses: 2
    Dernier message: 11/07/2008, 11h35
  5. Réponses: 4
    Dernier message: 22/12/2005, 17h05

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