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 Discussion :

Boucle For Next infinie sur enregistrement des pieces jointes


Sujet :

VBA

  1. #1
    Membre à l'essai
    Inscrit en
    Juin 2010
    Messages
    14
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 14
    Points : 14
    Points
    14
    Par défaut Boucle For Next infinie sur enregistrement des pieces jointes
    j'ai déjà posté ce problème dans le forum VBA outlook, mais visiblement, il n'y a personne en +, mon problème n'a pas trop de rapport avec Outlook (2003) finalement !

    voilà ce qui m'amène ici : j'ai un petit souci avec le code ci dessous, visiblement il s'agit d'une boucle infinie mais je ne vois pas bien où est le problème.

    Voici les symptomes :
    - j'ai remarqué que sur For Next, il parcourt tous les mails de ma boîte, trouve mon mail, fait ce qu'il a à faire (enregistrer les pièces jointes, puis déplacer le mail) , passe au mail suivant, etc...
    Mais lorsqu'il a finit de parcourir les X messages de ma boite de réception, au lieu de s'arrêter, il recommence la procédure... et j'arrive à ce message d'erreur après X boucles :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    erreur d'exécution 123456789...
    Index de la matrice en dehors des limites
    - par contre, si le mail n'est pas présent dans la boite de réception, je n'ai pas d'erreur ...

    Voici le code, merci à vous pour votre aide :

    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
    34
    35
    36
    37
     
    'procedure d'enregistrement des pieces jointes du mail Enrichissement téléphonique
    Sub savePJ_enrichsmt_tel()
     
        Dim MonApply As Outlook.Application
        Dim MonMail As Outlook.MailItem
        Dim MonNSpace As Outlook.NameSpace
        Dim FldDossier As Outlook.MAPIFolder
        Dim DestFldDossier As Outlook.MAPIFolder
     
        Set MonApply = Outlook.Application
        Set MonNSpace = MonApply.GetNamespace("MAPI")
        Set FldDossier = MonNSpace.GetDefaultFolder(olFolderInbox)
        Set DestFldDossier = FldDossier.Folders("uace000")
     
        'Boucle afin de parcourir l'ensemble des E-mails présents dans le dossier Boîte de réception
        For i = 1 To FldDossier.Items.Count
            'instancie le mail suivant la valeur de la boucle
            Set MonMail = FldDossier.Items(i)
            'Test sur le sujet si égale à Invitation
            If InStr(1, MonMail.Subject, "FICHTEL_") > 0 Then
               For Each PJ In MonMail.Attachments
               PJ.SaveAsFile "T:\Transferts\Enrichismt_telephone\" & PJ.FileName
               Next
            MonMail.Move DestFldDossier
            'MonMail.Delete
            End If
        Next i
     
        'Vide des instances
        Set MonApply = Nothing
        Set MonNSpace = Nothing
        Set FldDossier = Nothing
        Set MonMail = Nothing
        Set DestFldDossier = Nothing
     
    End Sub

  2. #2
    Inactif  
    Profil pro
    Inscrit en
    Février 2010
    Messages
    517
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 517
    Points : 617
    Points
    617
    Par défaut
    salut

    je te suggère de commencer par le dernier et de remonter vers le premier

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For i =  FldDossier.Items.Count to 1
    pour éviter des croches-pieds dans l'autre sens

  3. #3
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 598
    Points : 34 286
    Points
    34 286
    Par défaut
    salut,
    il sera bon de specifier le Step -1 a la fin pour que le code puisse tourner dans la boucle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For i =  FldDossier.Items.Count to 1 Step -1
    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 :
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

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

    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

  4. #4
    Inactif  
    Profil pro
    Inscrit en
    Février 2010
    Messages
    517
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 517
    Points : 617
    Points
    617
    Par défaut
    Citation Envoyé par jpcheck Voir le message
    salut,
    il sera bon de specifier le Step -1 a la fin pour que le code puisse tourner dans la boucle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For i =  FldDossier.Items.Count to 1 Step -1
    Salut
    Bien sur
    Oops et merci d'avoir complété

  5. #5
    Membre à l'essai
    Inscrit en
    Juin 2010
    Messages
    14
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 14
    Points : 14
    Points
    14
    Par défaut
    ça marche nickel, merci à vous 2 !

    Et pour ceux que ça interesse, ce script permet d'enregistrer le ou les fichiers en pièces jointes d'un ou plusieurs emails présent dans votre boite de réception Outlook et correspondant à vos critères (moi, je me limite à une partie du sujet, mais vous pouvez aussi filtrer sur l'expediteur...) sur un disque dur puis déplace l'email dans un sous dossier de la boite de réception.

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

Discussions similaires

  1. [OL-2010] Enregistrement automatique des pieces jointe sur outlook
    Par nassiri dans le forum Outlook
    Réponses: 1
    Dernier message: 06/11/2014, 10h12
  2. VB6 Arret boucle FOR NEXT par appui sur un bouton
    Par obel38 dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 04/01/2011, 16h35
  3. faire une boucle for..next sur des textbox
    Par Actarusdu60 dans le forum VB.NET
    Réponses: 1
    Dernier message: 28/11/2008, 21h51
  4. [VB6] Problème contrôle Timer et boucle For-Next ...
    Par Stéphane BEHMENBURG dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 01/12/2005, 17h36
  5. Réponses: 3
    Dernier message: 03/11/2005, 19h22

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