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 :

VBA fonction répétée en tache de fond ?


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2013
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2013
    Messages : 9
    Par défaut VBA fonction répétée en tache de fond ?
    Bonjour,

    Je réalise un script en VBA afin de contrôler SAP.
    Afin de gérer une erreur, je cherche à savoir comment il est possible d'exécuter une fonction en tache de fond.
    Un peu à la manière de "on error goto" mais je sais comment détecter l'erreur.

    En gros la solution qui marcherai ce serai d'exécuter ma fonction (que je sais écrire et qui me sort de mon erreur) avant l'exécution de chaque ligne de code. Ma fonction faire une vérification et si cas de figure de bug, résous le problème.

    Quelqu'un a til comprend et peut m'aider?

    Merci

  2. #2
    Membre émérite
    Homme Profil pro
    ingénieur d'étude
    Inscrit en
    Juin 2013
    Messages
    563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : ingénieur d'étude
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2013
    Messages : 563
    Par défaut
    Bonjour,

    Citation Envoyé par spiker15 Voir le message
    Quelqu'un a til comprend et peut m'aider?
    Euh..., pas vraiment en fait. En effet, vous dîtes :
    Citation Envoyé par spiker15 Voir le message
    En gros la solution qui marcherai ce serai d'exécuter ma fonction (que je sais écrire et qui me sort de mon erreur) avant l'exécution de chaque ligne de code.
    Ce qui laisse penser que vous savez très bien comment faire : écrire, avant chacune des lignes de code qui contrôle SAP, un appel à la fonction que vous citez...

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2013
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2013
    Messages : 9
    Par défaut
    Tout à fait !

    Mais n'y a t-il pas possibilité de gérer ça différemment plutôt que d'appeler ma fonction avant chaque ligne de code ?
    Parce que c'est un peu sale de faire comme ça ...

  4. #4
    Membre émérite
    Homme Profil pro
    ingénieur d'étude
    Inscrit en
    Juin 2013
    Messages
    563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : ingénieur d'étude
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2013
    Messages : 563
    Par défaut
    Tout dépend de la diversité des lignes de codes que vous souhaitez utiliser.

    En gros il va s'agir d'inclure la ligne voulue dans une fonction dédiée, qui exécutera précédemment la fonction de vérification.
    Cela est applicable si les commandes envoyées à SAP sont en nombre de limité.
    Mais si vous utilisez 50 commandes différentes, chacune une seule fois, il va vous falloir créer 50 fonctions dédiées. Et chacune ne sera utilisée qu'une seule fois... ce qui revient à inclure directement la fonction de vérification avant chaque ligne !

    A l'inverse, si toutes les commandes que vous envoyez ne dépendent que d'une chaîne de caractère (par exemple), une seule fonction dédié qui prendra en argument la chaîne en question sera suffisante.
    Et dans ce cas, intégrer la vérification au début de la fonction est dédiée sera très efficace.

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2013
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2013
    Messages : 9
    Par défaut
    Oué, malheureusement j'ai beaucoup de fonctions très différentes.

    Il n'est pas possible d'inclure au début du code un truc du genre :

    On (test de verification) goto (code de résolution de ce pb)

    Parce que mettre ma fonction de résolution a chaque ligne c'est lourd.

    Merci

  6. #6
    Membre émérite
    Homme Profil pro
    ingénieur d'étude
    Inscrit en
    Juin 2013
    Messages
    563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : ingénieur d'étude
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2013
    Messages : 563
    Par défaut
    Je ne connais aucune méthode pour faire simplement ce que vous demandez.
    Et ce post semble me donner raison

Discussions similaires

  1. [AC-2010] VBA fonctionnement en tache de fond
    Par vandrie dans le forum VBA Access
    Réponses: 4
    Dernier message: 14/12/2013, 15h40
  2. Réponses: 3
    Dernier message: 07/06/2005, 15h44
  3. [application tache de fond] lancer une application
    Par jean-jacques varvenne dans le forum Général Python
    Réponses: 5
    Dernier message: 25/03/2005, 12h13
  4. executer une page en tache de fond
    Par Invité(e) dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 22/01/2005, 17h23
  5. [Question] serveur en tache de fond
    Par Nicaisse dans le forum Réseau
    Réponses: 11
    Dernier message: 14/08/2003, 11h47

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