私は非常にプログラミングの面倒で、ExcelでVBA(マクロレコーダー)を使用しています。バルク添付ファイル名で保存する
私は約500の大口支出、収入、毎月の予算レポートを送付します。これらのレポートにはそれぞれ固有の件名があります。サンプルの件名は "Report 001"となり、Excelの添付ファイルを "Project A 2016"として保存します。件名が「レポート002」の場合は、ファイルを「プロジェクトB 2015」などと保存してください。
もう1つの考えは、ファイル名を保存するためのvLookupを使用するExcelテーブルを参照することです。この新しいものと私は方向性が欠けている。
**更新** 2017年7月7日
コード、私のニーズに働いて、下記掲載されています。コードはhttp://www.fontstuff.com/outlook/oltut01pfv.htmに基づいています。
コードでは、特定の件名の電子メールを受け取り、デスクトップに特定の命名規則でファイルを保存します。
コードをより効率的にすることはできますか?これは4つの電子メールサブジェクトのブロックであり、500個以上のバッチが存在する可能性があるため、csvファイルなどを参照するループを作成できますか?ここ
Sub GetAttachments6()
' This Outlook macro checks a named subfolder in the Outlook Inbox
' (here the "Sales Reports" folder) for messages with attached
' files of a specific type (here file with an "xls" extension)
' and saves them to disk. Saved files are timestamped. The user
' can choose to view the saved files in Windows Explorer.
' NOTE: make sure the specified subfolder and save folder exist
' before running the macro.
On Error GoTo SaveAttachmentsToFolder_err
' Declare variables
Dim ns As NameSpace
Dim Inbox As MAPIFolder
Dim SubFolder As MAPIFolder
Dim Item As Object
Dim Atmt As Attachment
Dim FileName As String
Dim i As Integer
Dim varResponse As VbMsgBoxResult
Set ns = GetNamespace("MAPI")
Set Inbox = ns.GetDefaultFolder(olFolderInbox)
Set SubFolder = Inbox.Folders("AutoRunReport") ' Enter correct subfolder name.
i = 0
' Check subfolder for messages and exit of none found
If SubFolder.Items.Count = 0 Then
MsgBox "There are no messages in the AutoRunReport folder.", vbInformation, _
"Nothing Found"
Exit Sub
End If
' Check each message for attachments
For Each Item In SubFolder.Items
For Each Atmt In Item.Attachments
If Left(Item.Subject, 36) = "Monthly Auto Gen Report CY LD01_0210" Then
FileName = "C:\Users\drowan\Desktop\TestTestTest\" & "LAB 2016 11 ENY 2016 0290000210 ADMIN" & ".pdf"
Atmt.SaveAsFile FileName
i = i + 1
End If
If Left(Item.Subject, 36) = "Monthly Auto Gen Report PY LD01_0210" Then
FileName = "C:\Users\drowan\Desktop\TestTestTest\" & "LAB 2016 11 ENY 2015 0290000210 ADMIN" & ".pdf"
Atmt.SaveAsFile FileName
i = i + 1
End If
If Left(Item.Subject, 37) = "Monthly Auto Gen Report PPY LD01_0210" Then
FileName = "C:\Users\drowan\Desktop\TestTestTest\" & "LAB 2016 11 ENY 2014 0290000210 ADMIN" & ".pdf"
Atmt.SaveAsFile FileName
i = i + 1
End If
If Left(Item.Subject, 36) = "Monthly Auto Gen Report CY LD01_0215" Then
FileName = "C:\Users\drowan\Desktop\TestTestTest\" & "LAB 2016 11 ENY 2016 0290000215 HR" & ".pdf"
Atmt.SaveAsFile FileName
i = i + 1
End If
Next Atmt
Next Item
' Show summary message
If i > 0 Then
varResponse = MsgBox("I found " & i & " attached files." _
& vbCrLf & "I have saved them into the C:\Desktop\TestTestTest folder." _
& vbCrLf & vbCrLf & "Would you like to view the files now?" _
, vbQuestion + vbYesNo, "Finished!")
' Open Windows Explorer to display saved files if user chooses
If varResponse = vbYes Then
Shell "Explorer.exe /e,C:\Users\drowan\Desktop\TestTestTest\", vbNormalFocus
End If
Else
MsgBox "I didn't find any attached files in your mail.", vbInformation, "Finished!"
End If
' Clear memory
SaveAttachmentsToFolder_exit:
Set Atmt = Nothing
Set Item = Nothing
Set ns = Nothing
Exit Sub
' Handle Errors
SaveAttachmentsToFolder_err:
MsgBox "An unexpected error has occurred." _
& vbCrLf & "Please note and report the following information." _
& vbCrLf & "Macro Name: GetAttachments" _
& vbCrLf & "Error Number: " & Err.Number _
& vbCrLf & "Error Description: " & Err.Description _
, vbCritical, "Error!"
Resume SaveAttachmentsToFolder_exit
End Sub
与えられた4つの例のために働くこと
からファイル名を算出し、いくつかのコードですか?いくつかのコードを投稿してください。 – mjsqu
あなたが何をしようとしているかは完全にわかりません。同じテーマを持つメッセージに添付ファイルをまとめてグループ化しますか?その場合は、電子メールコレクションを繰り返し処理し、その添付ファイルをすべて同じフォルダに保存するのではなく、電子メールの件名に基づいて名前を付けたサブフォルダに保存するコードを記述できます。あなたは、フォルダ名では有効ではない件名に可能な文字のようないくつかのトラップをかわす必要がありますが、それはあなたのニーズを満たすかもしれません。 – VBobCat
こんにちは、https://stackoverflow.com/questions/15531093/save-attachments-to-a-folder-and-rename-themを参照し、 '.subject'プロパティを使ってファイルを特定するように編集することができます名前など – AiRiFiEd