目次
Outlookの指定フォルダ配下のメールの添付ファイルをPCの指定フォルダに保存する
この記事では、Microsoft Access上で利用可能な「SaveMailAttachmentsFromOutlookFolder」というユーザー定義関数について紹介します。
この関数を「MakeFolderNameTableForOutlook」と合わせて Access 内のマクロ内に数行追加して呼び出すことで、Outlookの指定フォルダ内のメールの添付ファイルを、PCの指定フォルダに簡単に保存できます。
しかもこの記述の中に利用者個人のアカウント名、フォルダの絶対パス名等を記述する必要がないため、これらの関数を使って作成したOutlookメールの保存ツールのチーム内での横展開も簡単です。
この情報が読者の皆様のお役に立てることを願っています。
解決できること
毎日、Microsoft Outlookのメールやその添付ファイルを手動保存し、売上やプロジェクトの管理表等を更新するのは、本当に面倒ですよね。
こうした作業を行うために部下の方や、派遣社員の方にこうした作業を任せている方も多いのではないでしょうか。
でもそれって本来かけなくていい、時間やコストをかけているのではありませんか?
この記事では、Microsoft Accessで利用できる「SaveMailAttachmentsFromOutlookFolder」という優れたユーザー定義関数をご紹介します。
この関数を「MakeFolderNameTableForOutlook」と合わせて Access の autoexec マクロ内に数行追加して呼び出すことで、自動的にOutlookの指定入力フォルダ内の全てのメールに添付された添付ファイルを%USERPROFILE%からの相対パスで指定されたWindowsフォルダに保存し、更に必要に応じてそれらのメールをOutlookの指定出力フォルダに移動するツールを数分で作成することができます。
そして作成したこのツールをタスクスケジューラ等から自動起動されるバッチファイルから呼び出すことで、Microsoft Outlookのメールの保存作業を自動化し、劇的に時間やコストの効率化を図れます。
是非ご利用を検討ください。
読んでほしい方
この記事では、Access VBAでツールの開発をしている方や、業務効率化や費用削減を推進されている方に向けMicrosoft Outlookのメールの自動保存ツール作成方法に関する情報を提供しています。
特に、ツールを第三者に提供する際に利用者の環境差分を Access VBAや、マクロの中に記述したくない方には、必見の内容です。
この関数を「MakeFolderNameTableForOutlook」と合わせて Access の autoexec マクロ内に数行追加して呼び出すことで、自動的にOutlookの指定入力フォルダ内の全てのメールに添付された添付ファイルをそのまま%USERPROFILE%からの相対パスで指定されたWindowsフォルダに保存し、更に必要に応じてそれらのメールをOutlookの指定出力フォルダに移動する柔軟性や拡張性、保守性の高いツールを数分で作成することができます。
SaveMailAttachmentsFromOutlookFolder関数 の紹介
説明
「MakeFolderNameTableForOutlook」を利用して作成した、以下のテーブルを参照して
Outlookの入力フォルダを指定し、そのフォルダ内の全てのメールを%USERPROFILE%からの相対パスで指定された PC のフォルダ配下に 入力フォルダ名 & “_” & メール受信時間 & “.txt” というファイル名で保存します。
更に同様にこのテーブルを参照したOutlookの出力フォルダが指定された場合、これらのメールを指定された出力フォルダに移動します。
参照オブジェクト
このユーザー定義関数を利用するためにはこの関数の実行前に
データベースツール > Visual Basic > ツール > 参照設定
で以下の画面を表示し
- Microsoft Office 16.0 Access Database engine
- Microsoft Outlook 16.0 Object Library
- Microsoft ActiveX Data Object 6.1 Library
にチェックを入れる必要があります。
利用例
Access のマクロ定義 “autoexec“マクロの中で 例えば以下のように
“M0000_Call_MakeFolderNameTableForOutlook” 、
“M020_SaveMailAttachmentsFromOutlookFolder” を定義しておき
“M020_SaveMailAttachmentsFromOutlookFolder” の中では以下のように
If SaveMailAttachmentsFromOutlookFolder("OutLookFolderes","Microsoft365_In","Tools_Data_Temp\accdb","Microsoft365_Out")>0 Then
メッセージボックス ("Microsoft365_In" 配下のメール添付ファイルの保存に失敗しました。,はい,なし)
If 文の最後
SaveMailAttachmentsFromOutlookFolderを “OutLookFolderes“,”Microsoft365_In“,”Tools_Data_Temp\accdb“,”Microsoft365_Out“のようなパラメータを付けて呼び出すようにしておきます。
そして Outlookを起動状態にして
この “autoexec” マクロをダブルクリックして実行すると、Outlook の “Microsoft365_In” 配下の全メールの添付ファイルをそのままの名前で %USERPROFILE% からの相対パス “Tools_Data_Temp\accdb” 配下に格納し、そのメールそのものを Outlook の “Microsoft365_Out” 配下へ移動します。
メール本文保存先フォルダ名として指定する%USERPROFILE% からの相対パスについては必要に応じて以下の記事を参考にしてください。
またこのツールの起動前にOutlookが起動していることを保証するための方法については同様に以下の記事を参考にしてください。
引数
属性 | 入力条件 | 意味 | |
---|---|---|---|
テーブル名 | 文字型 | 必須 | MakeFolderNameTableForOutlook で作成された参照テーブルの名前を””で囲んだ文字列で関数のパラメータとして指定します。 |
Outlook内対象フォルダ名 | 文字型 | 必須 | Outlook または “OutLookFolderes” テーブルの内容を事前に確認し、メール保存したいOutlook の対象フォルダ名を、””で囲んだ文字列で関数のパラメータとして指定します。 |
メール添付ファイル保存先フォルダ名 | 文字型 | 必須 | %USERPROFILE% からの相対パスで指定されたメール本文の保存先フォルダ名を””で囲んだ文字列で関数のパラメータとして指定します。 |
Outlook内移動先フォルダ名 | 文字型 | 任意 |
Outlook または “OutLookFolderes” テーブルの内容を事前に確認し、メール本文保存後のこのメールの移動先Outlookフォルダ名を、””で囲んだ文字列で関数のパラメータとして指定します。 このパラメータはオプション指定であり、指定されなかった場合には対象メールの移動は行いません。 |
戻り値
値 | 意味 |
---|---|
0 | 正常終了 |
1 | 異常終了 |
VBAコード
SaveMailAttachmentsFromOutlookFolder
このAccess VBAコードは、Outlookフォルダ内のメールアイテムに添付された添付ファイルをを保存する関数です。
この関数のパラメータには、保存するメールアイテムとその添付ファイルを含むOutlookフォルダ内の入力フォルダの名前、保存するPC内の出力パス、および必要に応じてメールアイテムを移動するOutlookフォルダ内の出力フォルダの名前が必要です。
この関数は、指定された入力フォルダ内のすべてのメールアイテムに添付された添付ファイルをそのまま指定されたPC内の出力パスへ保存し、またOutlookフォルダ内の出力フォルダが指定された場合、メールアイテムを移動します。
最後にこの関数は成功コード0または失敗コード1を返します。
Public Function SaveMailAttachmentsFromOutlookFolder(ByVal table_name As String, ByVal in_folder_name As String, ByVal out_path As String, Optional ByVal out_folder_name As String) As Integer
' 成功コードと失敗コードを定数として設定する
Const C_SUCCESS As Integer = 0
Const C_FAILURE As Integer = 1
' 必要なオブジェクト、変数、コレクションを宣言する
Dim myNamespace As Object
Dim inFolder As Object
Dim outFolder As Object
Dim mailItem As Object
Dim objAttachments As Outlook.Attachments
Dim objAttachment As Outlook.Attachment
Dim fullpath As String
Dim index As Integer
Dim mailItemsToProcess As Collection
Set mailItemsToProcess = New Collection
On Error GoTo ErrorHandler
' Outlook アプリケーションおよび名前空間オブジェクトを作成する
Set myNamespace = CreateObject("Outlook.Application").GetNamespace("MAPI")
' 入力フォルダーをフォルダーパスを解析して取得する
Set inFolder = getOutlookFolder(table_name, in_folder_name, myNamespace)
' 出力フォルダーが指定されている場合は取得する
If Not out_folder_name = "" Then
Set outFolder = getOutlookFolder(table_name, out_folder_name, myNamespace)
End If
' 出力先のパスを設定する
fullpath = Environ("UserProfile") & "\" & out_path & "\"
' 処理するメールアイテムのコレクションを作成する
For Each mailItem In inFolder.Items
mailItemsToProcess.Add mailItem
Next mailItem
' メールアイテムコレクションの各メールアイテムに対して処理を実行する
For Each mailItem In mailItemsToProcess
' すべての添付ファイルをフォルダに保存する
Set objAttachments = mailItem.Attachments
For index = 1 To objAttachments.Count
Set objAttachment = objAttachments.Item(index)
objAttachment.SaveAsFile fullpath & objAttachment.FileName
Next index
' 出力フォルダーが指定されている場合はメールを移動する
If Not out_folder_name = "" Then
mailItem.Move outFolder
End If
Next mailItem
' オブジェクトを解放する
Set mailItem = Nothing
Set outFolder = Nothing
Set inFolder = Nothing
Set myNamespace = Nothing
Set objAttachments = Nothing
Set objAttachment = Nothing
' 成功コードを返す
SaveMailAttachmentsFromOutlookFolder = C_SUCCESS
ExitFunction:
Exit Function
ErrorHandler:
Debug.Print Err.Description
' エラーが発生した場合はオブジェクトを解放し、失敗コードを返す
Set mailItem = Nothing
Set outFolder = Nothing
Set inFolder = Nothing
Set myNamespace = Nothing
Set objAttachments = Nothing
Set objAttachment = Nothing
' 失敗コードを返す
SaveMailAttachmentsFromOutlookFolder = C_FAILURE
Resume ExitFunction
End Function
SaveMailAttachmentsFromOutlookFolderの簡単な説明
行番号 | 説明 |
---|---|
1 | 関数名と関数の戻り値の型(Integer:整数型)、値参照型の入力パラメータtable_name 、 in_folder_name、out_path、out_folder_name の名前、型(String:文字列型)を定義しています。ここに out_folder_name は省略可能ですが、省略した場合にはメールのOutlookフォルダ間での移動は行いません。 |
3-5 | このプログラムの中で利用する定数C_SUCCESS(0:成功)、C_FAILURE(1:失敗)を定義しています。ここではnn行目、mm行目でこの関数の戻り値が 成功か失敗かが明確にわかるように定数定義しています。 |
7-19 |
この関数の中で利用される |
17-18 | Outlook アプリケーションと名前空間オブジェクトを作成する。 |
21 | この関数の実行中にエラーが発生したときの例外処理として、ErrorHandler にジャンプします。 |
23-24 |
Outlook アプリケーションおよび名前空間オブジェクトを作成します。 |
26-27 |
入力フォルダーのフォルダーパスを解析してOutlookのフォルダを取得する。 |
29-32 |
出力フォルダーが指定されている場合はそのフォルダーパスを解析してOutlookのフォルダを取得する。 |
34-35 |
出力先PCフォルダの絶対パス名を設定する。 |
37-40 |
処理するメールアイテムのコレクションを作成する。 これは、inFolder.Items を直接参照して 42行目以降の処理を実行すると、メールの移動の際にin.Folder.Itemsの内容が変化し、処理が途中で中断してしまうため、この回避処理としてメールアイテムをコレクション化しています。 |
42-58 |
メールアイテムコレクションの各メールアイテムの添付ファイルそのまま指定PCフォルダに書き込みます。 |
60-69 | 使用オブジェクトをメモリ解放し、この関数の戻り値に C_SUCCESS(0:成功) を設定して関数を終わります。 |
71-86 | エラーが発声した場合、そのエラー原因をVBEのイミディエイトウインドウに出力し、使用オブジェクトをメモリ解放し、最後にこの関数の戻り値に C_FAILURE (1:失敗) を設定して関数を終わります。 |
ご覧頂いているように Outlook のオブジェクト構造はなかなか複雑なので
必要に応じて以下の参考図書を参照されることをお勧めします。
getOutlookFolder
この関数は、Outlookのフォルダーを取得する関数で、SaveMailItemBodyFromOutlookFolder で使用されているものと同じです。詳細については必要に応じて関連記事を参照下さい。
まとめ
この記事では、Microsoft Access上で利用可能な「SaveMailAttachmentsFromOutlookFolder」というユーザー定義関数について紹介しました。
この関数を「MakeFolderNameTableForOutlook」と合わせて Access 内のマクロ内に数行追加して呼び出すことで、Outlookの指定フォルダ内のメールの添付ファイルを、PCの指定フォルダに簡単に保存できます。
しかもこの記述の中に利用者個人のアカウント名、フォルダの絶対パス名等を記述する必要がないため、これらの関数を使って作成したOutlookメールの保存ツールのチーム内での横展開も簡単です。
この情報が読者の皆様のお役に立てることを願っています。
この関数の利用にあたっては
が必要です。また
を目的として、対象メールは本文の保存後、オプションで指定する出力フォルダに移動できるようにしています。
出力フォルダ側に移動したメールは他のフォルダ配下のメール同様、Outlookのフォルダの プロパティ>古いアイテムの整理 を使って、一定期間前に受信したメールに対して以下のオプションを選択し、Outlookのメール格納フォルダが無駄に増大し、Outlookがクラッシュしたりしないようにしておきましょう。