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

Enregistrement automatique des Mails en .msg dans un dossier


Sujet :

VBA Outlook

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Apprenti Ingénieur Génie Industriel
    Inscrit en
    Février 2016
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Apprenti Ingénieur Génie Industriel
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2016
    Messages : 7
    Points : 7
    Points
    7
    Par défaut Enregistrement automatique des Mails en .msg dans un dossier
    Bonjour à tous,

    ci-joint deux procédures qui permettent d'enregistrer le dernier mail dans un dossier sur le bureau.
    le but serait donc d'enregistrer chaque mail à sa réception dans le dossier.

    Mais le problème étant le déclenchement du code : lorsque je le programme à l'arrivé d'un nouveau message, il s’exécute avant d'afficher le nouveau message, enregistrant alors l'avant dernier...
    Une des solutions serait de programmer ce code sur minuterie mais je ne sais pas comment faire.

    Si vous avez des solutions ou des idées je suis à l'écoute !
    Merci d'avance !

    Code déclenché sur réception :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Sub Script(MyMail As MailItem)                'ou Private Sub Application_NewMail() marcherait aussi 
     
        Dim MonOutlook As Outlook.Application
        Dim lemail As Object
        Dim LesMails As Outlook.Selection
        Set bdr = Outlook.CreateObject(test)
        Set MonOutlook = Outlook.Application
     
                           'recupère le dernier mail
           sav_mail_as_msg MonOutlook.ActiveExplorer.CurrentFolder.Items(MonOutlook.ActiveExplorer.CurrentFolder.Items.Count)
     
    End Sub
    Il en appelle à celui ci :
    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
    Sub sav_mail_as_msg(Optional objCurrentMessage As Object)
    'By Oliv' juillet 2007 pour OUTLOOK 2003
     
        If objCurrentMessage Is Nothing Then Set objCurrentMessage = ActiveInspector.CurrentItem
     
        'Ici on construit le nom du fichier qui sera créé
        NomExport = objCurrentMessage.ReceivedTime & " Objet  " & objCurrentMessage.Subject & " De  " & objCurrentMessage.SenderName
        'Ici on défini le répertoire où l'enregistrer
        repertoire = "D:\Users\Richard\Desktop\dossiermail\"
        'repertoire = BrowseForFolder("Choisissez la destination", SDossier(5, 0)) & "\"
     
        'Ici on supprime les caractères non autorisé dans les noms de fichiers
        PathNomExport = repertoire & Left(Replace(Replace(Replace(Replace(Replace(Replace(Replace(Replace(Replace(Replace(Replace(Replace( _
        NomExport, "\", ""), "/", ""), ":", ""), "*", ""), "?", ""), "<", ""), ">", ""), "|", ""), ".", ""), """", ""), vbTab, ""), Chr(7), ""), 160) & ".msg"
     
        'Ici on vérifie que le fichier n'existe pas déjà sinon il serait écrasé
        n = 1
        MemPath = PathNomExport
        While Dir(PathNomExport) <> ""
            'MsgBox "Le fichier " & vbCr & PathNomExport & vbCr & "existe déjà", vbInformation
            Exit Sub
            'PathNomExport = Left(MemPath, Len(MemPath) - 4) & "(" & n & ")" & ".msg"
            'n = n + 1
        Wend
        objCurrentMessage.SaveAs PathNomExport, OlSaveAsType.olMSG
     
    End Sub

  2. #2
    Membre expert Avatar de QuestVba
    Homme Profil pro
    Enseignant
    Inscrit en
    Juillet 2012
    Messages
    2 477
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 2 477
    Points : 3 864
    Points
    3 864
    Par défaut
    Bonjour,

    Tu ne pourrais pas utiliser une règle pour déclencher ton code ?

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Apprenti Ingénieur Génie Industriel
    Inscrit en
    Février 2016
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Apprenti Ingénieur Génie Industriel
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2016
    Messages : 7
    Points : 7
    Points
    7
    Par défaut [VBA] Enregistrement automatique des Mails en .msg dans un dossier
    Bonjour,
    Lorsque l'on nomme la procédure avec le fameux "script", cela permet de l'appeler avec une règle,
    j'ai d'ailleurs mis les deux possibilités ci-dessus, mais malheureusement, dans les deux cas mon problème reste le même
    Merci quand même !

Discussions similaires

  1. Réponses: 5
    Dernier message: 09/07/2007, 19h07
  2. Tri automatique des mails
    Par trois_1 dans le forum Réseau
    Réponses: 7
    Dernier message: 03/08/2006, 21h53
  3. Réponses: 5
    Dernier message: 20/07/2006, 16h01
  4. Réponses: 4
    Dernier message: 13/07/2006, 10h33
  5. Traitement automatique des mails.
    Par ourk dans le forum Linux
    Réponses: 2
    Dernier message: 23/09/2004, 18h14

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