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 :

Envoi de mails multiples - pièce jointe différente


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Juin 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Juin 2014
    Messages : 15
    Points : 3
    Points
    3
    Par défaut Envoi de mails multiples - pièce jointe différente
    J'ai lu cette discussion.

    Bonjour Dominique,

    Je reviens vers toi concernant ce code crée en 2011....
    je t'avoue que pour moi la VBA c'est un peu la 4eme dimension...

    Comment incorporer ces 2 lignes de variables au code ci dessus?

    merci de ton aide

  2. #2
    Invité
    Invité(e)
    Par défaut Bonjour,
    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 Test()
    Mail "Sujet ", "Message", "Destinataire@gmail.com", "DestinataireCopy@gmail.com", "DestinataireCopyCacher@gmail.com", "C:\MyTest\Classeur1.xlsm;C:\MyTest\Classeur11.xlsm"
     
    Mail "Sujet ", "Message", "Destinataire@gmail.com", Pj:="C:\MyTest\Classeur1.xlsm;C:\MyTest\Classeur11.xlsm"
    End Sub
     
    Sub Mail(Sujet As String, Message As String, Destinataire As String, Optional DestinataireCopy As String, Optional DestinataireCopyCacher As String, Optional Pj As String = "")
    Set objOutlook = CreateObject("Outlook.application")
    Set MailObj = objOutlook.CreateItem(olMailItem)
    With MailObj
        .To = Destinataire
        .CC = DestinataireCopy
        .BCC = DestinataireCopyCacher
        .Subject = Sujet
        .BodyFormat = 2
        .HTMLBody = Message
        If Trim("" & Pj) <> "" Then
            p = Split(Pj & ";", ";")
            For i = 0 To UBound(p)
                If Trim("" & p(i)) <> "" Then .Attachments.Add Trim("" & p(i))
            Next
        End If
        '.Display 'Can be .Send but prompts for user intervention before sending without 3rd party software like ClickYes
        .Send
    End With
     
    End Sub
    Dernière modification par AlainTech ; 09/06/2014 à 23h23. Motif: Suppression de la citation inutile

  3. #3
    Candidat au Club
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Juin 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Juin 2014
    Messages : 15
    Points : 3
    Points
    3
    Par défaut
    Merci robert,
    mais ce code n'a plus rien a voir avec celui d'origine...

  4. #4
    Invité
    Invité(e)
    Par défaut
    tu as raison il est mieux que l'origine il marche partout!
    la fonction Mail est utilisable sur n'import quelle vba.
    en plus il est simple à utiliser.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Mail "Sujet", "Message", "Destinataire@gmail.com", Pj:="C:\MyTest\Classeur1.xlsm;C:\MyTest\Classeur11.xlsm", DestinataireCopyCacher:="DestinataireCopyCacher@gmail.com"
    Mail "Sujet", "Message", "Destinataire@gmail.com", Pj:="C:\MyTest\Classeur1.xlsm;C:\MyTest\Classeur11.xlsm", DestinataireCopy:="DestinataireCopy.com"
    Mail "Sujet", "Message", "Destinataire@gmail.com", DestinataireCopy:="DestinataireCopy.com", DestinataireCopyCacher:="DestinataireCopyCacher@gmail.com"
    Mail "Sujet", "Message", "Destinataire@gmail.com",DestinataireCopyCacher:="DestinataireCopyCacher@gmail.com"
    Mail "Sujet", "Message", "Destinataire@gmail.com"
    en plus il fonctionne en HTML et il permet de multiplier les pièces jointent

    voici le même code
    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
    Sub envoi()
    Dim cel As Range, fc As String, admail As String
    Dim responsable As String, messmail As String
    responsable = "Toto"
    'ci-dessous une feuille "adresses"
    For Each cel In Sheets("adresses").Range("A2:a33") 'si les données (adresses mail et fichier à envoyer) sont en A et B
       admail = cel.Value
       fc = cel(1, 2).Value 'attention mettre chemin complet du fichier à envoyer
       messmail = "Bonjour" & Chr(10) & "Ci-joint, le fichier" & Chr(10) & Chr(10) & responsable
       'ci-dessous vérifier le chemin d'outlook
     If Trim("" & admail) <> "" Then Mail "CHALETS A JOUR", messmail, admail, Pj:=fc
    Next cel
    End Sub
     
     
    Sub Mail(Sujet As String, Message As String, Destinataire As String, Optional DestinataireCopy As String, Optional DestinataireCopyCacher As String, Optional Pj As String = "")
    Set objOutlook = CreateObject("Outlook.application")
    Set MailObj = objOutlook.CreateItem(olMailItem)
    With MailObj
        .To = Destinataire
        .CC = DestinataireCopy
        .BCC = DestinataireCopyCacher
        .Subject = Sujet
        .BodyFormat = 2
        .HTMLBody = Replace(Messagec, Chr(10), "<br>")
        If Trim("" & Pj) <> "" Then
            p = Split(Pj & ";", ";")
            For i = 0 To UBound(p)
                If Trim("" & p(i)) <> "" Then .Attachments.Add Trim("" & p(i))
            Next
        End If
        '.Display 'Can be .Send but prompts for user intervention before sending without 3rd party software like ClickYes
        .Send
    End With
     
    End Sub
    Dernière modification par AlainTech ; 09/06/2014 à 23h26. Motif: Fusion de 2 messages

  5. #5
    Candidat au Club
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Juin 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Juin 2014
    Messages : 15
    Points : 3
    Points
    3
    Par défaut
    Ok
    donc si je veux qu'il parte d'un tableur xl,
    quelle est le code pour :
    colonne A : adresse mail,
    colonne B : chemin du fichier

  6. #6
    Invité
    Invité(e)
    Par défaut
    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
    Sub test()
    Dim R As Range
    Dim L As Long
    Set R = ActiveSheet.UsedRange
    For L = 2 To R.Rows.Count'si la première linge est le titre
    'si non For L = 1 To R.Rows.Count
    If Trim("" & R(L, 1)) <> "" Then Mail "Etat des stocks", "Vous trouverez en pièce joint le fichier de compte rendu des provisions de sucettes !", R(L, 1), Pj:=R(L, 2)
    Next
    End Sub
     
     
    Sub Mail(Sujet As String, Message As String, Destinataire As String, Optional DestinataireCopy As String, Optional DestinataireCopyCacher As String, Optional Pj As String = "")
    Set objOutlook = CreateObject("Outlook.application")
    Set MailObj = objOutlook.CreateItem(olMailItem)
    With MailObj
        .To = Destinataire
        .CC = DestinataireCopy
        .BCC = DestinataireCopyCacher
        .Subject = Sujet
        .BodyFormat = 2
        .HTMLBody = Replace(Messagec, Chr(10), "<br>")
        If Trim("" & Pj) <> "" Then
            p = Split(Pj & ";", ";")
            For i = 0 To UBound(p)
                If Trim("" & p(i)) <> "" Then .Attachments.Add Trim("" & p(i))
            Next
        End If
        '.Display 'Can be .Send but prompts for user intervention before sending without 3rd party software like ClickYes
        .Send
    End With
     
    End Sub
    Dernière modification par AlainTech ; 09/06/2014 à 23h26. Motif: Suppression de la citation inutile

  7. #7
    Candidat au Club
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Juin 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Juin 2014
    Messages : 15
    Points : 3
    Points
    3
    Par défaut
    Jai le message d'erreur suivant :

    Erreur d'exécution '-2147024894 (80070002)':
    Fichier introuvable. Vérifier que le chemin d'accès et le nom du Fichier sont corrects.

    J'ai vérifier, tout est bon.

    En voulant deboguer, je tombe sur .Attachments.Add Trim("" & p(i))

  8. #8
    Invité
    Invité(e)
    Par défaut
    ajoutes ce code e regarde la fenêtre d'exécution touche [ctrl] + [G]
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    debug.print  Trim("" & p(i))

  9. #9
    Candidat au Club
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Juin 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Juin 2014
    Messages : 15
    Points : 3
    Points
    3
    Par défaut
    Le mail est envoyé, super,

    mais la pièce jointe ne l'ai pas

  10. #10
    Invité
    Invité(e)
    Par défaut
    tu as testé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     Debug.Print Trim("" & p(i))
    ?
    Dernière modification par AlainTech ; 09/06/2014 à 23h27. Motif: Suppression de la citation inutile

  11. #11
    Candidat au Club
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Juin 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Juin 2014
    Messages : 15
    Points : 3
    Points
    3
    Par défaut
    oui, je l'ai mis a la place de :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Then .Attachments.Add Trim("" & p(i))
    donc une erreur

    sur quelle ligne de code dois je le mettre?

  12. #12
    Invité
    Invité(e)
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    For i = 0 To UBound(p)
            Debug.Print Trim("" & p(i))
                If Trim("" & p(i)) <> "" Then .Attachments.Add Trim("" & p(i))
            Next
    Dernière modification par AlainTech ; 09/06/2014 à 23h29. Motif: Suppression de la citation inutile

  13. #13
    Candidat au Club
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Juin 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Juin 2014
    Messages : 15
    Points : 3
    Points
    3
    Par défaut
    J'ai le même message d'erreur que tout à l'heure

    Erreur d'exécution '-2147024894 (80070002)':
    Fichier introuvable. Vérifier que le chemin d'accès et le nom du Fichier sont corrects.

  14. #14
    Invité
    Invité(e)
    Par défaut
    il faut que tu regarde dans la fenêtre de débugage le résultat pour lactivé il faut appuyer simultanément sur les touches [CTRL] + [G]

  15. #15
    Candidat au Club
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Juin 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Juin 2014
    Messages : 15
    Points : 3
    Points
    3
    Par défaut
    merci de ta patience.
    je regarde

  16. #16
    Invité
    Invité(e)
    Par défaut
    je viens de me configurer une boîte gmail et Outlook que je n'utilise jamais, et ça marche j'ai même mis 3 pièces jointes!

  17. #17
    Candidat au Club
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Juin 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Juin 2014
    Messages : 15
    Points : 3
    Points
    3
    Par défaut
    J'ai compris,
    je n'avais pas mis l'extension .xlsx

    comme un débutant en VBA....

    Merci beaucoup de ton aide et de ta patience

  18. #18
    Candidat au Club
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Juin 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Juin 2014
    Messages : 15
    Points : 3
    Points
    3
    Par défaut
    Bonjour Rober,
    Tout fonctionne,
    seulement le corps du mail est vide malgré

    merci de ton aide

  19. #19
    Invité
    Invité(e)
    Par défaut
    comment renseigne tu les variable sujet et message?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    sujet="Etat des stocks"
    message="Vous trouverez en pièce joint le fichier de compte rendu des provisions de sucettes !"
    Mail  sujet,message , R(L, 1), Pj:=R(L, 2)
    Dernière modification par AlainTech ; 09/06/2014 à 23h30. Motif: Suppression de la citation inutile

Discussions similaires

  1. [XL-2002] Envoi de mails multiples - pièce jointe différente
    Par Phanloga dans le forum Macros et VBA Excel
    Réponses: 12
    Dernier message: 30/04/2011, 10h06
  2. [webdev]envoi de mail avec pièce jointe
    Par kwakly dans le forum WebDev
    Réponses: 3
    Dernier message: 11/02/2009, 11h07
  3. [Mail] Problème d'envoi de mail avec pièces jointes
    Par nelly644 dans le forum Langage
    Réponses: 2
    Dernier message: 31/03/2007, 10h14
  4. Envoie de Mail avec Pièce jointe
    Par Yaz dans le forum Struts 1
    Réponses: 2
    Dernier message: 12/07/2006, 13h51
  5. Envoi de mail avec pièce jointe
    Par gids01 dans le forum API standards et tierces
    Réponses: 1
    Dernier message: 20/04/2006, 13h15

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