基于主题的文件名保存批量附件

时间:2017-07-03 22:54:33

标签: vba email outlook outlook-vba email-attachments

我对编程非常陌生,并且一直在使用Excel中的VBA(宏录制器)。

我将按月发送大约500份批量支出,收入和预算报告,这些报告都有自己独特的主题。示例主题行将是"报告001"我想将Excel附件保存为"项目A 2016"。如果主题是"报告002"然后将文件另存为" Project B 2015"等

另一个想法是引用一个使用vLookup的Excel表来保存文件名是合适的。这一切都是新的,而且我没有方向。

**更新** 7/7/2017

根据我的需求编写的代码发布在下面。该代码基于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

1 个答案:

答案 0 :(得分:0)

这里有一些代码可以解析附件名称并从中

计算文件名

它适用于给出的四个例子

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

    Dim folderItems As Items
    Set folderItems = GetNamespace("MAPI").GetDefaultFolder(olFolderInbox).Folders("AutoRunReport").Items

    If folderItems.Count = 0 Then                                     ' Check subfolder for messages and exit of none found
        MsgBox "There are no messages in the AutoRunReport folder.", _
        vbInformation, "Nothing Found"
        GoTo ok_exit
    End If

    Dim Item As Object
    Dim Atmt As Attachment
    Dim subjElm() As String                                             ' array of subject line elements
    Dim fileName As String
    Dim year As String
    Dim deptNum As String
    Dim deptName As String
    Dim saveLocation As String

    saveLocation = "C:\Users\drowan\Desktop\TestTestTest\"

    Const sep As String = " "                                          ' separator between elements of resulting filename

    Dim filePrefix As String
    filePrefix = "LAB" & sep & "2016" & sep & "11" & sep & "ENY"       ' begining of each filename

            ' guesses and assumptions made:
            '     LD01_0215 and 0290000xxx signify department numbers
            '     last digit of department number (eg. LD01_0215) is department type
            '     cy, py, ppy .. are year codes

            ' "Monthly Auto Gen Report CY LD01_0210"  ==> "LAB 2016 11 ENY 2016 0290000210 ADMIN"
            ' "Monthly Auto Gen Report PY LD01_0210"  ==> "LAB 2016 11 ENY 2015 0290000210 ADMIN"
            ' "Monthly Auto Gen Report PPY LD01_0210" ==> "LAB 2016 11 ENY 2014 0290000210 ADMIN"
            ' "Monthly Auto Gen Report CY LD01_0215"  ==> "LAB 2016 11 ENY 2016 0290000215 HR"


    Dim i As Integer
    i = 0

    For Each Item In folderItems                                       ' Check each message for attachments
        For Each Atmt In Item.Attachments
            subjElm = Split(LCase(Item.Subject), " ", , vbTextCompare) ' split subject line into an array of words (zero based array)
                                                                       ' lcase function converts subject line to lower case

            '     0      1     2      3     4      5                   ' resulting index values of each element
            ' [Monthly][Auto][Gen][Report][PY][LD01_0210]              ' example subject line split into elements

            Select Case Trim(subjElm(4))
                Case "cy"
                    year = "2016"
                Case "py"
                    year = "2015"
                Case "ppy"
                    year = "2014"
                Case Else                  ' unspecified year
                    year = "noYear"
            End Select

            deptNum = "029000" & Split(subjElm(5), "_")(1)             ' [LD01_0210] ==> [LD01][0210]

            Select Case Right(Trim(subjElm(5)), 1)                     ' last character of LD01_0210
                Case "0"
                    deptName = "ADMIN"
                Case "5"
                    deptName = "HR"
                Case Else                  ' unspecified department
                    deptName = "noDeptName"
            End Select

            fileName = saveLocation & filePrefix & sep & year & sep & deptNum & sep & deptName & ".xls"
            Debug.Print "file path: " & fileName
            Atmt.SaveAsFile fileName

            i = i + 1

        Next Atmt
    Next Item


    If i > 0 Then                                    ' Show summary message

        Dim varResponse As VbMsgBoxResult

        varResponse = MsgBox("I found " & i & " attached file(s)." & vbCrLf _
                           & "I have saved them into the following folder:" & vbCrLf & vbCrLf _
                           & saveLocation & vbCrLf & vbCrLf _
                           & "Would you like to view the files now?" _
                           , vbQuestion + vbYesNo, "Finished!")

        If varResponse = vbYes Then
            Shell "Explorer.exe /e," & saveLocation, vbNormalFocus        ' Open Windows Explorer to display saved files
        Else
            MsgBox "I didn't find any attached files in your mail.", vbInformation, "Finished!"
        End If

    End If
    GoTo ok_exit

' Handle Errors
SaveAttachmentsToFolder_err:
    MsgBox "An unexpected error has occurred." & vbCrLf _
         & "Please note and report the following information." & vbCrLf & vbCrLf _
         & "Macro Name:" & vbTab & "GetAttachments" & vbCrLf & vbCrLf _
         & "Error Number:" & vbTab & Err.Number & vbCrLf & vbCrLf _
         & "Error Description:" & vbTab & Err.Description _
         , vbCritical, "Error!"

ok_exit:
    Set Atmt = Nothing      ' Clear memory
    Set Item = Nothing
    Set folderItems = Nothing
End Sub