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 :

Recuperer liste Mail Outlook - Mismatch


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Responsable de projet
    Inscrit en
    Décembre 2005
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Responsable de projet

    Informations forums :
    Inscription : Décembre 2005
    Messages : 97
    Par défaut Recuperer liste Mail Outlook - Mismatch
    Bonjour à tous, je sèche sur une macro qui récupère la liste des mails dans mon outlook et les dispose dans une feuille Excel.
    La macro est lancé depuis Excel.

    Ci-dessous le code, je me retrouve avec une erreur 13 Type Mismatch au niveau de "For Each OLmail In OLinbox.Items".
    La macro m'affiche 11 mails sur 15 avant de planter.
    Avez vous une idée ?

    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 getAllMails()
     
        Dim OLapp As Outlook.Application
        Dim OLspace As Outlook.Namespace
        Dim OLinbox As Outlook.MAPIFolder
        Dim OLfolder As Outlook.MAPIFolder
        Dim OLmail As Outlook.MailItem
        Dim i As Double
        Dim out As Variant
     
        Set OLapp = CreateObject("Outlook.application")
        Set OLspace = OLapp.GetNamespace("MAPI")
        Set OLinbox = OLspace.GetDefaultFolder(olFolderInbox)
     
        i = 2
        For Each OLmail In OLinbox.Items
            Range("A" & i).Value = OLmail.Subject
     
            i = i + 1
        Next
     
        Set OLapp = Nothing
        Set OLspace = Nothing
        Set OLinbox = Nothing
     
    End Sub

  2. #2
    Expert éminent


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Par défaut
    bonsoir,

    les "Items" ne sont pas forcément des mails Items ..

    modifie ta ligne 8

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
      Dim OLmail  'As Outlook.MailItem

    et pour ta boucle

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    ...
    For Each OLmail In OLinbox.Items
       If TypeName(OLmail) = "MailItem" Then
            Range("A" & i).Value = OLmail.Subject ' :( pas terrible le Range..non -préfixé de  la feuille de destination 
     
          Else
            Debug.Print "Type non pris en compte :" & TypeName(OLmail)
            Stop ' CTRL+G pour afficher fenêtre exécution F5 pour continuer
          End If 
     
     
            i = i + 1
        Next

Discussions similaires

  1. [Toutes versions] Afficher un élément d'une liste dans un mail outlook
    Par hassine dans le forum SharePoint
    Réponses: 11
    Dernier message: 08/11/2010, 11h39
  2. Récupérer les mails Outlook dans une table Access
    Par zerrokooll dans le forum VBA Access
    Réponses: 79
    Dernier message: 07/07/2009, 14h22
  3. Réponses: 2
    Dernier message: 29/08/2008, 15h31
  4. recuperer des mails stocker dans base MySQL avec Outlook
    Par freddy92110 dans le forum Outlook
    Réponses: 1
    Dernier message: 06/11/2005, 19h26
  5. Récupération de mail : quelle technologie utiliser
    Par lamoufle dans le forum Général Conception Web
    Réponses: 8
    Dernier message: 10/08/2005, 13h48

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