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 :

Comment récupérer le compte d'un MailItem ?


Sujet :

VBA Outlook

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 3
    Points : 1
    Points
    1
    Par défaut Comment récupérer le compte d'un MailItem ?
    Bonjour

    Je dois récupérer par programmation la liste des dossiers d'Entourage contenant des emails d'un compte précis.
    Plusieurs comptes POP3 et IMAP sont définis dans Entourage et je souhaite établir la liste des dossiers ayant des mails de l'un de ces comptes.
    Or, je ne vois aucun moyen de voir sur quel compte est arrivé un email (la classe "MailItem" n'a pas de propriété "Account").

    J'avais alors pensé utiliser l'adresse email liée au compte, mais là non plus, je ne vois pas de propriété du genre emailAddress dans la classe Account.
    Merci de vos lumières.

  2. #2
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Salut,

    en reprenant le code d'Heureux-oli:
    Comment parcourir les messages présents dans la boîte de réception ?

    tu peux récupérer l'adresse au quel le mail a été envoyé :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Sub ParcourirInBox()
        Dim oMail As MailItem
        Dim myFolder As Folder
        Dim myOlApp As Outlook.Application
        Dim myNamespace As NameSpace
     
     
        Set myOlApp = Outlook.Application
        Set myNamespace = myOlApp.GetNamespace("MAPI")
        Set myFolder = myNamespace.GetDefaultFolder(olFolderInbox)
        For Each oMail In myFolder.Items
            Debug.Print oMail.ReceivedByName
        Next oMail
    End Sub

    Dolphy

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    Merci, je teste ce mercredi.
    Mais alors, comment récupérer l'adresse email liée au compte ?

  4. #4
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    re,

    Citation Envoyé par Véhem Voir le message
    Merci, je teste ce mercredi.
    Mais alors, comment récupérer l'adresse email liée au compte ?

    il suffit d'utiliser d'autres propriétés de l'objet MailItem :

    SendUsingAccount => Renvoie ou définit un objet Account qui représente le compte sous lequel MailItem doit être envoyé. En lecture/écriture. dispo sur Ol2007
    ReceivedByName => Renvoie une valeur de type String qui représente le nom complet du vrai destinataire du message électronique. Lecture seule.
    SenderEmailAddress => Renvoie une valeur de type String représentant l'adresse de messagerie de l'expéditeur de l'élément Outlook. Lecture seule.
    SenderName => Renvoie une valeur de type String indiquant le nom complet de l'expéditeur de l'élément Outlook. Lecture seule.
    SenderEmailType => Renvoie une valeur de type String représentant le type d'entrée correspondant à l'adresse de messagerie de l'expéditeur de l'élément Outlook, par exemple, une adresse Internet « SMTP », la chaîne « EX » pour une adresse serveur Microsoft Exchange, etc. Lecture seule.

    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
    Sub ParcourirInBox()
        Dim oMail As MailItem
        Dim myFolder As Folder
        Dim myOlApp As Outlook.Application
        Dim myNamespace As NameSpace
     
     
        Set myOlApp = Outlook.Application
        Set myNamespace = myOlApp.GetNamespace("MAPI")
        Set myFolder = myNamespace.GetDefaultFolder(olFolderInbox)
        For Each oMail In myFolder.Items
            'SendUsingAccount => Outlook 2007
            Debug.Print "Compte : " & oMail.SendUsingAccount & " - " & "Destinataire : " & oMail.ReceivedByName & " - " & _
            "Email Expéditeur :" & oMail.SenderEmailAddress & " - " & "NomExpéditeur : " & oMail.SenderName & " - " & _
            "Type : " & oMail.SenderEmailType
        Next oMail
    End Sub

    Dolphy

  5. #5
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    SendUsingAccount n'est valorisé que pour les mails envoyés, pas pour les mails reçus.
    Il n'y a pas de propriété du genre SentToAccount.....

    Dans la classe Account, il n'y a pas de propriété emailAddress. En plus, si je veux accéder à UserName, j'ai un message de Win demandant s'il doit bien donner accès à cette donnée. Sécurité, sécurité.....

    Donc, en résumant, il semble qu'il soit impossible de sélectionner un compte, d'en récupérer l'adresse email associée puis de scanner les emails pour voir ceux qui ont été émis vers ce compte.
    Il faut saisir directement l'adresse email et ne pas prendre en compte...les comptes. C'est un peu bête ça.

Discussions similaires

  1. Réponses: 5
    Dernier message: 18/08/2014, 18h00
  2. Comment récupérer le nom du compte Système ?
    Par masterx_goldman dans le forum Windows
    Réponses: 6
    Dernier message: 29/10/2009, 12h52
  3. Comment récupérer mon compte administrateur?
    Par lolo52 dans le forum Administration
    Réponses: 0
    Dernier message: 09/12/2008, 18h49
  4. Comment récupérer mon compte admin ?
    Par Papy_CPC1512 dans le forum Windows Vista
    Réponses: 9
    Dernier message: 02/07/2008, 16h16
  5. Réponses: 2
    Dernier message: 22/08/2007, 12h46

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