Skip to main content

如何在Excel中發送帶有多個附件的電子郵件?

Author: Siluvia Last Modified: 2025-05-12

本文介紹了如何通過Outlook發送帶有多個附件的Excel電子郵件。

使用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」 選項,然後點擊「確定」按鈕。

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. 點擊命令按鈕運行代碼。在彈出的「瀏覽」窗口中,選擇您需要附加到郵件中的文件,然後點擊「確定」按鈕。參見截圖:

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作為郵件程序時有效。


輕鬆通過Outlook根據Excel中創建的郵件列表字段發送郵件:

Kutools for Excel 的「發送電子郵件」功能幫助用戶通過Outlook根據Excel中創建的郵件列表發送郵件。
立即下載並試用!(30-天免費試用)

send email with attachments by kutools


相關文章:

最佳辦公效率工具

🤖 Kutools AI 助手:基於智能執行方式革新數據分析:智能執行   |  生成代碼  |  創建自訂公式  |  分析數據並生成圖表  |  調用 Kutools 函數
熱門功能查找、標記重複值或識別重複項   |  刪除空行   |  合併列或單元格而不丟失數據   |   四捨五入無需公式 ...
高級 LOOKUP多條件 VLookup    多值 VLookup  |   多表查找   |   模糊查找 ....
高級下拉列表快速創建下拉列表   |  依賴下拉列表   |  多選下拉列表 ....
列管理器添加特定數量的列  |  移動列  |  切換隱藏列的可見狀態  |  比較區域和列 ...
特色功能網格聚焦   |  設計檢視   |   增強編輯欄    工作簿與工作表管理器   |  資源庫(自動文本)   |  日期提取器   |  合併資料   |  加密/解密儲存格    按列表發送電子郵件   |  超級篩選   |   特殊篩選(篩選粗體/斜體/刪除線...) ...
頂級 15 種工具集12 個文本工具添加文本刪除特定字符、...)   |   50+ 圖表 類型甘特圖、...)   |   40+ 實用 公式基於生日計算年齡、...)   |   19 個插入工具插入QR碼根據路徑插入圖片、...)   |   12 個轉換工具金額轉大寫匯率轉換、...)   |   7 個合併與分割工具高級合併行分割儲存格、...)   |   ... 還有更多

使用 Kutools for Excel 提升您的 Excel 技巧,體驗前所未有的高效。 Kutools for Excel 提供超過 300 種高級功能來提高生產力並節省時間。  點擊這裡獲取您最需要的功能...


Office Tab 將標籤式界面帶到 Office,讓您的工作更加輕鬆

  • 在 Word、Excel、PowerPoint、Publisher、Access、Visio 和 Project 中啟用標籤式編輯和閱讀。
  • 在同一窗口的新標籤中打開和創建多個文檔,而不是在新窗口中。
  • 將您的生產力提高 50%,每天為您減少數百次鼠標點擊!