[Outlook] 複数のメールから添付ファイルを一括で取得する方法
data:image/s3,"s3://crabby-images/a3916/a39166a0ffc5f317319da55d78e38c44c993efaa" alt=""
最近、働き方改革やDXで紙での連絡が減った分、メールの添付ファイルで通知されることが増えました。
通知がメール1つなら簡単なのですが、たくさんのメールで通知されることも少なくありません。
(集約するの大変!添付ファイル1つずつ保存していくの大変!)
そこで、今回は Outlook で受信した複数のメールから、まとめて添付ファイルを保存する方法を紹介します。
Outlookを起動する
起動してください(/・ω・)/
data:image/s3,"s3://crabby-images/247af/247af8e995ad3c7aefe315308cacd4c0bc2d5872" alt=""
VBA のウィンドウを開く
Alt + F11 を押します。
data:image/s3,"s3://crabby-images/327e2/327e2464c447801f5ff24dcf2ada85285c3aa7ff" alt=""
標準モジュールを挿入
Project1 にフォーカスを合わせて、 挿入>標準モジュール を選びます。
data:image/s3,"s3://crabby-images/e23b8/e23b824513117e6b18c60b683df16c1aadf9e1f3" alt=""
プログラムを貼り付け
挿入した標準モジュールを選択して、プログラムを貼り付けます。
data:image/s3,"s3://crabby-images/c6e3e/c6e3ed9aa3c488ea8eb44bd6af739fffdbebe763" alt=""
貼り付けるプログラムはこちらです。
Public Sub SaveAttachmentFiles()
On Error Resume Next
Dim saveDir As String
saveDir = CreateObject("WScript.Shell").SpecialFolders(16) & "\Attachment Files\"
If VBA.Dir(saveDir, vbDirectory) = vbNullString Then
VBA.MkDir saveDir
End If
Dim mailItem As Outlook.mailItem
Dim attachments As Outlook.attachments
Dim selection As Outlook.selection
Dim i As Long
Set selection = Outlook.Application.ActiveExplorer.selection
For Each mailItem In selection
Set attachments = mailItem.attachments
If attachments.Count > 0 Then
For i = attachments.Count To 1 Step -1
If IsEmbedded(attachments.Item(i)) = False Then
attachments.Item(i).SaveAsFile FileRename(saveDir & attachments.Item(i).FileName)
End If
Next i
End If
Next
Set selection = Nothing
Set attachments = Nothing
Set mailItem = Nothing
MsgBox saveDir & "に保存しました!"
End Sub
Function FileRename(FilePath As String) As String
On Error Resume Next
FileRename = FileRenameRecursive(FilePath, FilePath)
End Function
Function FileRenameRecursive(FilePath As String, BasePath As String, Optional Count As Long = 1) As String
On Error Resume Next
Dim path As String
path = FilePath
FileRenameRecursive = path
Dim fileSystemObject As fileSystemObject
Set fileSystemObject = CreateObject("Scripting.FileSystemObject")
If fileSystemObject.FileExists(path) Then
path = fileSystemObject.GetParentFolderName(BasePath) & "\" & fileSystemObject.GetBaseName(BasePath) & " (" & Count & ")." + fileSystemObject.GetExtensionName(BasePath)
FileRenameRecursive = FileRenameRecursive(path, BasePath, Count + 1)
End If
fileSystemObject = Nothing
End Function
Function IsEmbedded(Attach As Attachment)
On Error Resume Next
IsEmbeddedAttachment = False
Dim mailItem As mailItem
Set mailItem = Attach.Parent
If mailItem.BodyFormat <> olFormatHTML Then Exit Function
Dim cid As String
cid = ""
cid = Attach.PropertyAccessor.GetProperty("http://schemas.microsoft.com/mapi/proptag/0x3712001F")
If cid <> "" Then
If InStr(mailItem.HTMLBody, "cid:" & cid) > 0 Then
IsEmbeddedAttachment = True
End If
End If
End Function
ライブラリの参照設定
Microsoft Scripting Runtime を参照できるようにします。
data:image/s3,"s3://crabby-images/9b775/9b775964915a5f822d7662c1211d6dd9840f39fd" alt=""
data:image/s3,"s3://crabby-images/904a1/904a112ac6292189a194a09e6b081635ff097a74" alt=""
ツール>参照設定 から、Microsoft Scripting Runtime にチェックを入れて OK を押してください。
実行
実行してみます。
先に Outlook の画面で添付ファイルを保存したいメールを選んでおきます。
(CTRL押しながらぽちぽちして、複数選択していきます。)
そして、タブメニューから 実行>マクロの実行 です。
data:image/s3,"s3://crabby-images/76804/76804b809b79c7fe0d0b29e31a008fb2bc34f68a" alt=""
現在のフォーカスがある位置によっては次のダイアログがでるので、 SaveAttachmentFiles を選んで実行をおします。
data:image/s3,"s3://crabby-images/805ce/805ce06961d3db5459bfb0044af22573c6dca1cf" alt=""
保存が完了すると、保存先のパスが表示されて完了です。
data:image/s3,"s3://crabby-images/cd555/cd555bce447479c27b694998a6ba091c1c50a39b" alt=""
1つ1つのメールからファイルを順番にダウンロードするような修行からさよならしよう(。-`ω-)