メインコンテンツへスキップ

Excelで複数の添付ファイルを含むメールを送信するにはどうすればよいですか?

Author: Siluvia Last Modified: 2025-08-06

この記事では、Excelで複数の添付ファイルを追加してOutlook経由でメールを送信する方法について説明します。

VBAコードを使用してExcelで複数の添付ファイル付きのメールを送信する


VBAコードを使用してExcelで複数の添付ファイル付きのメールを送信する

以下のように操作して、Excelで複数の添付ファイル付きのメールを送信してください。

1. 開発タブをクリックし、挿入 > コマンドボタン(ActiveXコントロール)を選択してコマンドボタンを挿入してください。スクリーンショットをご覧ください:

click Command Button from Developer tab

2. コマンドボタンを挿入した後、右クリックしてコンテキストメニューから「 コードの表示」を選択してください。

select View Code from the context menu

3. 表示されたMicrosoft Visual Basic for Applicationsウィンドウで、以下のスクリーンショットに示すようにツール > 参照設定をクリックしてください。

click Tools > References

4. 「参照設定 - VBAProject」ダイアログボックスで、「 Microsoft Outlook Object Library 」オプションを探してチェックを入れ、OKボタンをクリックしてください。

check the Microsoft Outlook Object Library option in the dialog box

5. 次に、コードウィンドウ内の元のコードを以下のVBAコードに置き換えてください。

VBAコード: Excelで複数の添付ファイル付きのメールを送信する

Private Sub CommandButton1_Click()
    Dim xStrFile As String
    Dim xFilePath As String
    Dim xFileDlg As FileDialog
    Dim xFileDlgItem As Variant
    Dim xOutApp As Outlook.Application
    Dim xMailOut As Outlook.MailItem
    Application.ScreenUpdating = False
    Set xOutApp = CreateObject("Outlook.Application")
    Set xMailOut = xOutApp.CreateItem(olMailItem)
    Set xFileDlg = Application.FileDialog(msoFileDialogFilePicker)
    If xFileDlg.Show = -1 Then
        With xMailOut
            .BodyFormat = olFormatRichText
            .To = "happy.xuebi@163.com"
            .Subject = "test"
            .HTMLBody = "test"
            For Each xFileDlgItem In xFileDlg.SelectedItems
                .Attachments.Add xFileDlgItem
            Next xFileDlgItem
            .Display
        End With
    End If
    Set xMailOut = Nothing
    Set xOutApp = Nothing
    Application.ScreenUpdating = True
End Sub

注釈: メールの受信者、件名、本文を指定するには、コード内の .To = happy.xuebi@163.com.Subject = "test"、および .HTMLBody = "test" の行を変更してください。

6. Alt + Q キーを同時に押して、Microsoft Visual Basic for Applicationsウィンドウを終了します。

7. 開発タブをクリックし、デザインモードをオフにしてください。スクリーンショットをご覧ください:

Click Design Mode to turn off the Design Mode

8. コマンドボタンをクリックしてコードを実行します。表示される参照ウィンドウで、メールに添付したいファイルを選択し、OKボタンをクリックしてください。スクリーンショットをご覧ください:

run code to select the files you need to attach in the email

9. これで、指定されたフィールドと添付ファイルがリストアップされたメールが作成されます。送信ボタンをクリックしてメールを送信してください。スクリーンショットをご覧ください:

an email is created with specified fields and attachments listed out

注釈: このVBAコードは、Outlookをメールプログラムとして使用している場合にのみ動作します。


Excelで作成されたメーリングリストのフィールドに基づいて、簡単にOutlook経由でメールを送信する:

The 電子メールを送信 機能は、 Kutools for Excel ユーザーがExcelで作成されたメーリングリストに基づいてOutlook経由でメールを送信することを支援します。
今すぐダウンロードしてお試しください! (30-日間無料トライアル)

send email with attachments by kutools


関連記事:

最高のオフィス生産性ツール

🤖 Kutools AI Aide:データ分析を革新:インテリジェント実行   |  コード生成  |  カスタム数式の作成  |  データを分析してグラフを生成  |  Kutools Functions を呼び出す
人気機能重複の検索・ハイライト・マーキング   |  空白行を削除   |  データを失わず列やセルを統合   |   丸める ...
スーパーLOOKUP複数条件VLOOKUP   複数値VLOOKUP  |  複数シートの検索  |  ファジーマッチ ....
高度なドロップダウンリストすばやくドロップダウンリストを作成   |  依存型ドロップダウンリスト   |  複数選択ドロップダウンリスト ....
列の管理:特定数の列を追加  | 列を移動  | 非表示列の表示状態を切り替え |  範囲と列の比較 ...
注目機能グリッドフォーカス   |  デザインビュー  |  強化された数式バー   ワークブック&ワークシートの管理   |  オートテキスト ライブラリ (Auto Text)   |  日付ピッカー   |  データの統合   |  セルの暗号化/復号化    リスト送信で電子メールを送信   |  スーパーフィルター   |   特殊フィルタ(太字/斜体/取り消し線でフィルタ...)
トップ15ツールセット12 種類のテキストツールテキストの追加特定の文字を削除など)  |  50 種以上のグラフ タイプガントチャートなど)  |  40を超える実用的な 数式誕生日に基づいて年齢を計算する、など)  |  19種の 挿入ツールQRコードの挿入パスから画像の挿入など)  |  12種類の 変換ツール単語に変換する通貨変換など)  |  7つの 結合&分割ツール高度な行のマージセルの分割など)  |  ...さらに多数
お好きな言語でKutoolsを使用できます ― 英語、スペイン語、ドイツ語、フランス語、中国語など40以上に対応!

Kutools for ExcelでExcelスキルを強化し、かつてない効率を体験しましょう。 Kutools for Excelは300以上の高度な機能で生産性向上と時間短縮を実現します。最も必要な機能を今すぐ取得...


Office TabはOfficeにタブ表示を追加し、作業効率を大幅に向上させます

  • Word、Excel、PowerPointでタブ編集とタブ閲覧を有効にします
  • 同じウィンドウ内の新しいタブで複数のドキュメントを開いたり作成したりできます。新しいウィンドウを開く必要はありません。
  • 生産性が50%向上し、1日に何百回ものマウスクリックも削減できます!