Inserer tableau excel dans mail outlook
Fermé
wil2168
-
Modifié le 20 janv. 2020 à 00:31
jordane45 Messages postés 38446 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 28 février 2025 - 21 janv. 2020 à 23:30
jordane45 Messages postés 38446 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 28 février 2025 - 21 janv. 2020 à 23:30
A voir également:
- Insérer un mail dans excel
- Yahoo mail - Accueil - Mail
- Insérer liste déroulante excel - Guide
- Insérer une vidéo dans powerpoint - Guide
- Insérer signature word - Guide
- Publipostage mail - Accueil - Word
3 réponses
jordane45
Messages postés
38446
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
28 février 2025
4 739
20 janv. 2020 à 07:00
20 janv. 2020 à 07:00
Bonjour
N'aurais tu pas oublié d'indiquer l'extension du fichier ?
.mail.attachements.Add "c:\update_sony_20180121"
N'aurais tu pas oublié d'indiquer l'extension du fichier ?
bonjour
en faite la ligne de code ne doit pas être mise
elle sert à mettre le fichier en pièce jointe
moi je souhaite avoir mon tableau excel dans le corps de mon mail
en faite la ligne de code ne doit pas être mise
elle sert à mettre le fichier en pièce jointe
moi je souhaite avoir mon tableau excel dans le corps de mon mail
jordane45
Messages postés
38446
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
28 février 2025
4 739
21 janv. 2020 à 23:30
21 janv. 2020 à 23:30
Une rapide recherche amène sur des liens tel que
https://social.msdn.microsoft.com/Forums/en-US/693f49a6-973a-4258-af3c-7ec05e1bb7a1/excel-vba-to-copy-table-to-outlook-body?forum=exceldev
Qui indique
Dans un module, coller le code :
et pour l'envoi du mail
https://social.msdn.microsoft.com/Forums/en-US/693f49a6-973a-4258-af3c-7ec05e1bb7a1/excel-vba-to-copy-table-to-outlook-body?forum=exceldev
Qui indique
Dans un module, coller le code :
Function RangetoHTML(rng As Range) Dim fso As Object Dim ts As Object Dim TempFile As String Dim TempWB As Workbook TempFile = Environ$("temp") & "\" & Format(Now, "dd-mm-yy h-mm-ss") & ".htm" 'Copy the range and create a new workbook to past the data in rng.Copy Set TempWB = Workbooks.Add(1) With TempWB.Sheets(1) .Cells(1).PasteSpecial Paste:=8 .Cells(1).PasteSpecial xlPasteValues, , False, False .Cells(1).PasteSpecial xlPasteFormats, , False, False .Cells(1).Select Application.CutCopyMode = False On Error Resume Next .DrawingObjects.Visible = True .DrawingObjects.Delete On Error GoTo 0 End With 'Publish the sheet to a htm file With TempWB.PublishObjects.Add( _ SourceType:=xlSourceRange, _ Filename:=TempFile, _ Sheet:=TempWB.Sheets(1).Name, _ Source:=TempWB.Sheets(1).UsedRange.Address, _ HtmlType:=xlHtmlStatic) .Publish (True) End With 'Read all data from the htm file into RangetoHTML Set fso = CreateObject("Scripting.FileSystemObject") Set ts = fso.GetFile(TempFile).OpenAsTextStream(1, -2) RangetoHTML = ts.readall ts.Close RangetoHTML = Replace(RangetoHTML, "align=center x:publishsource=", _ "align=left x:publishsource=") 'Close TempWB TempWB.Close savechanges:=False 'Delete the htm file we used in this function Kill TempFile Set ts = Nothing Set fso = Nothing Set TempWB = Nothing End Function
et pour l'envoi du mail
Sub Mail_Selection_Range_Outlook_Body() Dim rng As Range Dim OutApp As Object Dim OutMail As Object Set rng = Nothing On Error Resume Next 'Only the visible cells in the selection Set rng = Selection.SpecialCells(xlCellTypeVisible) 'You can also use a fixed range if you want 'Set rng = Sheets("YourSheet").Range("D4:D12").SpecialCells(xlCellTypeVisible) On Error GoTo 0 If rng Is Nothing Then MsgBox "The selection is not a range or the sheet is protected" & _ vbNewLine & "please correct and try again.", vbOKOnly Exit Sub End If With Application .EnableEvents = False .ScreenUpdating = False End With Set OutApp = CreateObject("Outlook.Application") Set OutMail = OutApp.CreateItem(0) On Error Resume Next With OutMail .To = "***@***" .CC = "" .BCC = "" .Subject = "This is the Subject line" .HTMLBody = RangetoHTML(rng) ' .Body = Selection.Paste .Display 'or use .Send // Le temps des tests, utiliser Display pour voir le résultat, puis après, une fois ok, remplacer par .Send pour envoyer le mail. End With On Error GoTo 0 With Application .EnableEvents = True .ScreenUpdating = True End With Set OutMail = Nothing Set OutApp = Nothing End Sub