エクセルのシートをPDF化して、Outlookに添付するVBAを紹介します。
data:image/s3,"s3://crabby-images/61e09/61e09653b9a358a4e69c33a07294fbe4c83edc1d" alt=""
エクセルファイルをそのままメールに添付できない時は多いですよね。
data:image/s3,"s3://crabby-images/d2bdf/d2bdf18fb1ba00163f918e72dfa344f39d5cf308" alt=""
data:image/s3,"s3://crabby-images/d2bdf/d2bdf18fb1ba00163f918e72dfa344f39d5cf308" alt=""
data:image/s3,"s3://crabby-images/d2bdf/d2bdf18fb1ba00163f918e72dfa344f39d5cf308" alt=""
そうですね。
請求書、領収書、発注書などはエクセルで計算させると便利ですが、
エクセルだと受け取った人も修正ができちゃいますよね。
data:image/s3,"s3://crabby-images/61e09/61e09653b9a358a4e69c33a07294fbe4c83edc1d" alt=""
data:image/s3,"s3://crabby-images/61e09/61e09653b9a358a4e69c33a07294fbe4c83edc1d" alt=""
data:image/s3,"s3://crabby-images/61e09/61e09653b9a358a4e69c33a07294fbe4c83edc1d" alt=""
今回は、PDF化したエクセルのシートをOutlookに添付します。
data:image/s3,"s3://crabby-images/cccce/cccce8bdfa452bf5e78f5850080ae4775f74bf5a" alt=""
data:image/s3,"s3://crabby-images/cccce/cccce8bdfa452bf5e78f5850080ae4775f74bf5a" alt=""
エクセルをPDF化してメールに添付する(outlook)VBA
エクセルをPDF化してメールに添付する(outlook)VBA
マクロが設定されているファイル名が「BOOK1.xlsm」の場合、次のようなメールが作成される。
data:image/s3,"s3://crabby-images/c97f5/c97f5cb598e86955b125956532eee55dc03d8a4a" alt=""
data:image/s3,"s3://crabby-images/c97f5/c97f5cb598e86955b125956532eee55dc03d8a4a" alt=""
Sub SendWorkSheetToPDF()
Dim Wb As Workbook
Dim FileName, MailA, TextA As String
Dim OutlookApp As Object
Dim OutlookMail As Object
Set Wb = Application.ActiveWorkbook
MailA = “——@aaaaaa.co.jp”
TextM = “Hello”
FileName = Wb.FullName
xIndex = VBA.InStrRev(FileName, “.”)
If xIndex > 1 Then FileName = VBA.Left(FileName, xIndex – 1)
FileName = FileName & “.pdf”
ActiveSheet.ExportAsFixedFormat Type:=xlTypePDF, FileName:=FileName
Set OutlookApp = CreateObject(“Outlook.Application”)
Set OutlookMail = OutlookApp.CreateItem(0)
With OutlookMail
.To = MailA
.CC = “”
.BCC = “”
.Subject = “こんにちは”
.Body = TextM
.Attachments.Add FileName
.Display
End With
Kill FileName
Set OutlookMail = Nothing
Set OutlookApp = Nothing
End Sub
data:image/s3,"s3://crabby-images/dba5d/dba5d705af3801f8ef373b93e982242eeba40766" alt=""
data:image/s3,"s3://crabby-images/dba5d/dba5d705af3801f8ef373b93e982242eeba40766" alt=""
解説
応用編
複数の宛先に、それぞれの内容に併せたファイルを添付したい場合
- シートを作成する
data:image/s3,"s3://crabby-images/3b94d/3b94d22dbcc449bf77870752ab1f9864829bf5ce" alt=""
data:image/s3,"s3://crabby-images/3b94d/3b94d22dbcc449bf77870752ab1f9864829bf5ce" alt=""
- 「一覧」シートに宛先とメールアドレスを記入する
data:image/s3,"s3://crabby-images/d08a4/d08a4d0b36cc98484a1f0c49fa1ef39ebfc4f84d" alt=""
data:image/s3,"s3://crabby-images/d08a4/d08a4d0b36cc98484a1f0c49fa1ef39ebfc4f84d" alt=""
- 宛先ごとのシートに内容を作成する
data:image/s3,"s3://crabby-images/13165/131656515f562b9fc985e7ab011b383a7678f19e" alt=""
data:image/s3,"s3://crabby-images/13165/131656515f562b9fc985e7ab011b383a7678f19e" alt=""
VBA
Sub SendWorkSheetToPDF()
Dim a As Long
Dim Wb As Workbook
Dim FileName, Company, MailA, TextA As String
Dim OutlookApp As Object
Dim OutlookMail As Object
On Error Resume Next
Set Wb = Application.ActiveWorkbook
a = Sheets(1).Cells(Rows.Count, 1).End(xlUp).Row
For i = 2 To a
Sheets(i).Select
Company = Sheets(1).Cells(i, 1)
MailA = Sheets(1).Cells(i, 2)
TextM = “添付ファイル参照”
FileName = Wb.FullName
xIndex = VBA.InStrRev(FileName, “.”)
If xIndex > 1 Then FileName = VBA.Left(FileName, xIndex – 1)
FileName = FileName & “_” & Company & “様.pdf”
ActiveSheet.ExportAsFixedFormat Type:=xlTypePDF, FileName:=FileName
Set OutlookApp = CreateObject(“Outlook.Application”)
Set OutlookMail = OutlookApp.CreateItem(0)
With OutlookMail
.To = MailA
.CC = “”
.BCC = “”
.Subject = “お支払額のご連絡”
.Body = Company & “ 様” & vbCrLf & vbCrLf & TextM
.Attachments.Add FileName
.Display
End With
Kill FileName
Set OutlookMail = Nothing
Set OutlookApp = Nothing
Next i
Sheets(1).Select
End Sub
解説
エラーの場合は次に進む
左から1番目のシート「一覧」・A列の最終行を取得する
2~aまでにおいて(ループ)
添付するシートを選択する
宛先の取得
メールアドレスの取得
本文の取得
添付ファイルのファイル名を作成
→ファイル名_宛先様.pdf
Outlookの設定
メールアドレス
CC
BCC
メールタイトル
本文:「宛先」様 <改行><改行> 本文
添付ファイルを作成
プレビュー ※直接送りたい場合は「Send」
それぞれを空にする
結果
data:image/s3,"s3://crabby-images/d1e5b/d1e5b4e3793fd1975a53c8fc8c4af070103d759e" alt=""
data:image/s3,"s3://crabby-images/d1e5b/d1e5b4e3793fd1975a53c8fc8c4af070103d759e" alt=""
data:image/s3,"s3://crabby-images/601f0/601f0e757b8132e32108f820b1280c5dd069c0e1" alt=""
data:image/s3,"s3://crabby-images/601f0/601f0e757b8132e32108f820b1280c5dd069c0e1" alt=""
data:image/s3,"s3://crabby-images/601f0/601f0e757b8132e32108f820b1280c5dd069c0e1" alt=""
エクセルをPDF化してメールに添付するVBAでした。
data:image/s3,"s3://crabby-images/0fc30/0fc30857e17ea8f83390650c014e1fe0b3622739" alt=""
data:image/s3,"s3://crabby-images/0fc30/0fc30857e17ea8f83390650c014e1fe0b3622739" alt=""
コメント