Skip to main content

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

Author: Siluvia Last Modified: 2025-08-06

本文介紹了如何通過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


相關文章:

最佳 Office 辦公效率工具

🤖 Kutools AI Aide:徹底革新數據分析,基於智能執行|生成程式碼|創建自訂公式|分析數據並生成圖表|調用 Kutools Functions
熱門功能查找、選取項目的背景色或標記重複值 | 刪除空行 | 合併列或單元格且不丟失資料 | 四捨五入...
高級 LOOKUP多條件查找|多值查找|多表查找|模糊查找...
高級下拉列表快速創建下拉列表 | 關聯下拉列表 | 多選下拉列表 ...
列管理器添加指定數量的列 | 移動列 | 切換隱藏列的可見狀態 | 區域與列比較 ...
精選功能網格聚焦 | 設計檢視 | 增強編輯欄 | 工作簿及工作表管理器 | 資源庫 (自動文本) | 日期提取器 | 合併資料 | 加密/解密儲存格 | 按清單發送電子郵件 | 超級篩選 | 特殊篩選(篩選粗體/傾斜/刪除線 ...)...
前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% 的工作效率,每天為你大量減少滑鼠點擊次數!