ここから本文です

複数メールの添付ファイルをまとめて保存したい

hit********さん

2011/3/1409:30:31

複数メールの添付ファイルをまとめて保存したい

Outlook2007を使用しております。

過去に受信・送信した添付ファイル付きメールの添付ファイルを
まとめて一括でPC内の1つのフォルダに保存したいと考えております。
添付ファイルは、1ファイルのメールもあれば、複数添付されているものもあります。

方法をご存じの方がいらっしゃいましたら教えてください。。。

閲覧数:
3,363
回答数:
1
お礼:
50枚

違反報告

ベストアンサーに選ばれた回答

ato********さん

編集あり2011/3/1508:01:08

マクロでよければ、、、あんまりテストしてないですが、、
#保存先の指定がないのでデスクトップに「添付保存」としました(なければ処理内で作ります)
#保存先に同一名のファイルがあれば連番をつけて保存されます
#送信済みアイテムとサブフォルダの処理は止めてますので必要ならコメントはずしてください

Public Sub S_Attachment_Save_Main()

Set lobjFso = CreateObject("Scripting.FileSystemObject")

lstrPath = CreateObject("WScript.Shell").SpecialFolders("Desktop") & "\" & "添付保存"
If Not lobjFso.FolderExists(lstrPath) Then
'#保存フォルダ作成
lobjFso.CreateFolder lstrPath
End If

'#受信トレイ
Call S_Attachment_Save(lstrPath, Application.Session.GetDefaultFolder(olFolderInbox))
'#送信済みアイテム
'Call S_Attachment_Save(lstrPath, Application.Session.GetDefaultFolder(olFolderSentMail))

MsgBox "...終わりました...", vbOKOnly + vbInformation, "メッセージ"

End Sub

Private Sub S_Attachment_Save(p_Path, p_Folder)

For Each lobjMsg In p_Folder.Items

If TypeName(lobjMsg) = "MailItem" Then

For Each lobjAttach In lobjMsg.Attachments

With lobjAttach

llngSequence = 1
'#受信日を加味するならlobjMsg.ReceivedTimeを加工
lstrName = p_Path & "\" & .FileName
While CreateObject("Scripting.FileSystemObject").FileExists(lstrName)
lstrName = p_Path & "\" & Left(.FileName, InStrRev(.FileName, ".") - 1) _
& "-" & llngSequence & Mid(.FileName, InStrRev(.FileName, "."))
llngSequence = llngSequence + 1
Wend

.SaveAsFile lstrName

End With
Next
End If
Next

'#サブフォルダ処理
'For Each lobjFolder In p_Folder.Folders
' Call S_Attachment_Save(p_Path, lobjFolder)
'Next

End Sub

質問した人からのコメント

2011/3/15 12:20:15

ありがとうございます。
バッチリうまくいきました。
とっても助かりました!!!

みんなで作る知恵袋 悩みや疑問、なんでも気軽にきいちゃおう!

Q&Aをキーワードで検索:

Yahoo! JAPANは、回答に記載された内容の信ぴょう性、正確性を保証しておりません。
お客様自身の責任と判断で、ご利用ください。
本文はここまでです このページの先頭へ

「追加する」ボタンを押してください。

閉じる

※知恵コレクションに追加された質問は選択されたID/ニックネームのMy知恵袋で確認できます。

不適切な投稿でないことを報告しました。

閉じる