XL 2016 Code vba envoi mail classeur excel

Benoooiiiittttt

XLDnaute Nouveau
Bonjour,
Voilà plusieurs jours que j’essaie de résoudre mon problème via les divers forum mais ça ne marche pas. Le problème restant sur le code ci-dessous : Lorsque j’exécute le code j'ai 2 fenêtres outlook qui s'ouvrent. 1 fenêtre avec le classeur entier(mais il manque le texte d'accompagnement), la 2eme s'ouvre avec seulement la feuille active mais avec le texte..Pouvez-vous m'indiquer la résolution à mon problème afin d'avoir 1 seul mail prêt à envoyer avec le classeur entier et le texte d'accompagnement? Merci d'avance
Le code:
[/CODE]
 

Benoooiiiittttt

XLDnaute Nouveau
VB:
Sub suite()
Pardon, le code:
Sub mail ()
If MsgBox("SOUHAITEZ-VOUS ENVOYER LE POINT CA PAR EMAIL ?" & Chr(13) & Chr(10) & "( Une nouvelle fenètre OUTLOOK va être ouverte )", 36, "Envoyer Email") = vbYes Then
  
    Dim OL As Object, myItem As Object, wDoc As Object, Rng As Object
    Dim Fichier As String, plage_mail As Range
    Set OL = CreateObject("Outlook.Application")
    Set myItem = OL.CreateItem(olMailItem)
    Set wDoc = myItem.GetInspector.WordEditor
    Set FL = Worksheets("Feuil1!")
    Set plage_mail = Worksheets("Feuil1!").Range("A1:K29")
            
    Workbooks("Monfichier.xlsm").Activate
    ActiveWorkbook.SendMail Recipients:=Range("c258954").Value
        Application.DisplayAlerts = True
 
    
  
    With myItem
        .To = ListeTo
        .Subject = "Blablabla"
        .Body = Worksheets("Base").Range("L6")
        .Attachments.Add Application.ActiveWorkbook.FullName
        .Display
        plage_mail.Copy
        Set Rng = wDoc.Content
        Rng.InsertParagraphAfter
        Rng.Move 4, 1
        Rng.Paste
        Rng.Move 4
        
            
           End With

End If
    
    Set OL = Nothing: Set myItem = Nothing: Set wDoc = Nothing
    'Remonte à la cellule de Sélection du Magasin
    Range("A1").Activate

End Sub

Function ListeTo()
    xCpt = 0
    With Sheets("Base")
        For Each xCell In .Range("C5")
            xCpt = xCpt + 1
            If xCpt = 1 Then
                xTo = xCell
            Else
                xTo = xTo & ";" & xCell
            End If
        Next xCell
    End With
    ListeTo = xTo
End Function


Private Sub CommandButton1_Click()

End Sub
 
C

Compte Supprimé 979

Guest
Re,

Vous auriez pu éditer votre 1er post et mettre le code dedans 🤔

A essayer et tester
VB:
Option Explicit

Const olMailItem As Integer = 0

Sub mail()
  Dim Fl As Worksheet
  Dim OL As Object, myItem As Object, wDoc As Object, Rng As Object
  Dim Fichier As String, Plage_Mail As Range

  If MsgBox("SOUHAITEZ-VOUS ENVOYER LE POINT CA PAR EMAIL ?" & vbCr _
          & "( Une nouvelle fenètre OUTLOOK va être ouverte )", vbYesNo, "Envoyer Email") = vbNo Then Exit Sub
 
  Set OL = CreateObject("Outlook.Application")
  Set myItem = OL.CreateItem(olMailItem)
  Set wDoc = myItem.GetInspector.WordEditor
  Set Fl = Worksheets("Feuil1!")
  Set Plage_Mail = Worksheets("Feuil1!").Range("A1:K29")
 
  With myItem
    .Display
    .To = ListeTo
    .Subject = "Blablabla"
    .Body = Worksheets("Base").Range("L6")
    Plage_Mail.Copy
    Set Rng = wDoc.Content
    Rng.InsertParagraphAfter
    Rng.Move 4, 1
    Rng.Paste
    Rng.Move 4
    .Attachments.Add Application.ActiveWorkbook.FullName
  End With

  Set OL = Nothing: Set myItem = Nothing: Set wDoc = Nothing
  'Remonte à la cellule de Sélection du Magasin
  Range("A1").Activate
End Sub

Function ListeTo()
  Dim xCell As Range, xCpt As Integer, xTo As String
  xCpt = 0
  With Sheets("Base")
    For Each xCell In .Range("C5")
      xCpt = xCpt + 1
      If xCpt = 1 Then
        xTo = xCell
      Else
        xTo = xTo & ";" & xCell
      End If
    Next xCell
  End With
  ListeTo = xTo
End Function

A+
 
Dernière modification par un modérateur:

Benoooiiiittttt

XLDnaute Nouveau
Merci pour la réponse très rapide. J'ai fait une mauvaise manip sur le premier envoi.

Je viens de tester, il me met une erreur de compilation variable non définie. En surlignant en bleu xCell de la ligne For each dans Function ListeTo (). Je suis novice en vba, je souhaite seulement automatiser un envoi pour gagner du temps. Merci pour ton aide
 

Discussions similaires

  • Question Question
Microsoft 365 Code VBA
Réponses
7
Affichages
605
Réponses
1
Affichages
349
Compte Supprimé 979
C
  • Question Question
Microsoft 365 Générer mail via Excel
Réponses
2
Affichages
680
  • Question Question
Réponses
15
Affichages
3 K
  • Question Question
Microsoft 365 Macro VBA - Excel
Réponses
12
Affichages
570
  • Question Question
Microsoft 365 Question code VBA
Réponses
2
Affichages
354
Réponses
10
Affichages
662