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

VBA Access Discussion :

Stopper une macro sous certaines conditions


Sujet :

VBA Access

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    149
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 149
    Points : 93
    Points
    93
    Par défaut Stopper une macro sous certaines conditions
    Bonsoir à tous,

    J'ai défini dans une base Access une Macro (grâce à l'assistant graphique). Ma Macro exécute des requêtes (via OuvrirRequête).

    Ma première requête importe des données dans une table, appelée "Table1".
    Ce que j'aimerai, c'est tester juste après s'il y a des champs vides, et si c'est vrai arrêter la macro, avec un message à l'écran. Si la table est ok, la macro s'éxécute normalement (en exécutant les autres requêtes)

    Ca vous semble possible?

    Merci

  2. #2
    Membre habitué
    Homme Profil pro
    Inscrit en
    Août 2007
    Messages
    184
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2007
    Messages : 184
    Points : 188
    Points
    188
    Par défaut
    Bonjour,
    Je n'utilise plus les macros...

    As tu une "obligation" d'utiliser une macro, ou peux tu faire cela en VBA ?

    si ta macro fonctionne, je te conseillerrais volontiers de l'enregistrer sous ..code VBA.

    dans ce code, tu ajoute les tests que tu veux :
    (par exemple avec Dcount, Dsum...)

    en fonction des tests avec des msgbox tu peux poursuivre ou non ton processus

    en espérant faire avancer...

    cordialement,
    fevec

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    149
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 149
    Points : 93
    Points
    93
    Par défaut
    Hello,

    Merci de ta réponse. Il faut par contre absolument que je passe par une macro "graphique". Il y a la possibilité d'ajouter la fonction "exécuterCode". Donc je pensais définir une procédure VBA, qui teste la table, et qui stoppe la macro lorsque des champs sont vides. Mais quel code me permet de stopper la macro, voilà le souci ...

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    235
    Détails du profil
    Informations personnelles :
    Localisation : Luxembourg

    Informations forums :
    Inscription : Juillet 2006
    Messages : 235
    Points : 176
    Points
    176
    Par défaut
    Salut,

    TU peux en VBA faire un recorset sur la table dont les données sont importées, vérifier s'il ya des enregistrements et ensuite executer ta macro.

    Voici un exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Set cop = CurrentDb.OpenRecordset("Composition FoF, date fixee")
    cop.MoveLast
    cop.MoveFirst
    MaxNAV = cop.RecordCount
     
    if (MAxNAV>0) then
    Call macro
    End if

Discussions similaires

  1. Réponses: 1
    Dernier message: 17/02/2015, 13h34
  2. Ajouter un champ dans une JSP sous certaines conditions
    Par intel42 dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 11/04/2012, 08h59
  3. Lancement d'une tâche sous certaines conditions
    Par Almindra dans le forum SSIS
    Réponses: 6
    Dernier message: 28/11/2011, 15h14
  4. Réponses: 3
    Dernier message: 06/12/2010, 20h13
  5. Réponses: 4
    Dernier message: 21/07/2010, 11h18

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