2

Outlookメッセージ内で受信したExcel添付ファイルを、受信トレイにある特定のサブフォルダー(毎日の最終版)に保存する必要があります。そのサブフォルダー内のすべての電子メールに、Excel添付ファイルが含まれることを知っています。以下にExcelVBAの例を示しましたが、機能していません。

 Sub SaveAttachmentsToFolder()
 ' This Outlook macro checks a named subfolder in the Outlook Inbox
 ' (here the "daily final" 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("daily final") ' 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 Sales Reports 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
 ' Check filename of each attachment and save if it has "xls" extension
 If Right(Atmt.FileName, 3) = "xls" Then
 ' This path must exist! Change folder name as necessary.
 FileName = "C:\Email Attachments\" & _
 Format(Item.CreationTime, "yyyymmdd_hhnnss_") &
Atmt.FileName
 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:\Email Attachments 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:\Email Attachments", 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

1 に答える 1

1

Webサイトから切り取って貼り付けたようですが、VBAに精通していません。コードをVBAコードウィンドウに貼り付けると、問題のある行が強調表示されます。次に、知識を適用してこれらの問題を修正します。たとえば、上からのこの行は1つのステートメントである必要があります。

MsgBox "There are no messages in the Sales Reports folder.",
vbInformation , _
 "Nothing Found"

そのようです:

MsgBox "Message", buttons, "Title"

ステートメントは、3行に同じように配置できますが、行継続文字(_)を使用する必要があります。1つしかなく、2つ必要です。

MsgBox "There are no messages in the Sales Reports folder.", _
vbInformation , _
 "Nothing Found"

ここ

FileName = "C:\Email Attachments\" & _
 Format(Item.CreationTime, "yyyymmdd_hhnnss_") &

余分な&があります。ステートメントを&で終わらせることはできません

F1キーは、このような状況で非常に役立ちます。

于 2012-07-02T13:23:56.307 に答える