如何将 Excel 中的每个工作表分别发送到不同的邮箱地址?
如果您有一个包含多个工作表的 Excel 文件,且每个工作表的 S1 单元格中都包含一个邮箱地址,您或许希望将每个工作表作为单独的附件发送给对应的收件人。手动完成这项任务不仅耗时,而且在处理大量工作表时尤为繁琐。在本教程中,我们将为您演示如何通过 VBA 代码,自动将 Excel 文件中的每个工作表作为附件,发送至各工作表 S1 单元格中指定的邮箱地址。
使用 VBA 代码从 Excel 将每个工作表发送给不同的邮箱地址
以下 VBA 代码可将每个工作表作为附件,发送给 S1 单元格中指定的对应收件人。请按以下步骤操作:
1. 按下 Alt + F11 键,即可同时打开 Microsoft Visual Basic for Applications 窗口。
2. 然后,单击插入 > 模块,并将下方的 VBA 代码复制粘贴到窗口中。
VBA 代码:将每个工作表作为附件发送给不同的邮箱地址
Sub Mail_Every_Worksheet()
'Updateby ExtendOffice
Dim xWs As Worksheet
Dim xWb As Workbook
Dim xFileExt As String
Dim xFileFormatNum As Long
Dim xTempFilePath As String
Dim xFileName As String
Dim xOlApp As Object
Dim xMailObj As Object
On Error Resume Next
With Application
.ScreenUpdating = False
.EnableEvents = False
End With
xTempFilePath = Environ$("temp") & "\"
If Val(Application.Version) < 12 Then
xFileExt = ".xls": xFileFormatNum = -4143
Else
xFileExt = ".xlsm": xFileFormatNum = 52
End If
Set xOlApp = CreateObject("Outlook.Application")
For Each xWs In ThisWorkbook.Worksheets
If xWs.Range("S1").Value Like "?*@?*.?*" Then
xWs.Copy
Set xWb = ActiveWorkbook
xFileName = xWs.Name & " of " _
& VBA.Left(ThisWorkbook.Name, VBA.InStr(ThisWorkbook.Name, ".") - 1) & " "
Set xMailObj = xOlApp.CreateItem(0)
xWb.Sheets.Item(1).Range("S1").Value = ""
With xWb
.SaveAs xTempFilePath & xFileName & xFileExt, FileFormat:=xFileFormatNum
With xMailObj
'specify the CC, BCC, Subject, Body below
.To = xWs.Range("S1").Value
.CC = ""
.BCC = ""
.Subject = "This is the Subject line"
.Body = "Hi there"
.Attachments.Add xWb.FullName
.Display
End With
.Close SaveChanges:=False
End With
Set xMailObj = Nothing
Kill xTempFilePath & xFileName & xFileExt
End If
Next
Set xOlApp = Nothing
With Application
.ScreenUpdating = True
.EnableEvents = True
End With
End Sub
- S1 是包含您要发送电子邮件的邮箱地址的单元格。如果您的邮箱地址位于其他单元格(例如 )A1),只需修改代码即可适配该位置。
- 您可以在代码中自行指定抄送(CC)、密送(BCC)、主题(Subject)和正文(Body);
- 若要直接发送电子邮件而不弹出新邮件窗口,您需将 .Display 更改为 .Send。

3. 然后,按下 F5 键运行此代码,每个工作表将自动作为附件插入到新邮件窗口中,如下图所示:

4. 最后,单击发送按钮,即可逐个发送每封电子邮件。
Kutools for Excel:一键轻松发送个性化邮件!

厌倦了逐封发送客户邮件?借助 Kutools for Excel 的“发送邮件”功能,沟通更高效、更专业!只需在 Excel 表格中准备好姓名、邮箱地址、注册码,并插入相应占位符,系统即可自动生成个性化邮件,一键群发数百封,彻底告别重复劳动!
- 💡 动态占位符(如姓名、注册码)可自动为每位收件人填充个性化内容,让每封邮件都显得量身定制。
- 📎 附加个性化文件,确保准确送达
- 📤 与 Outlook 无缝集成,实现安全可靠的发送
- 📝 保存并重复使用电子邮件模板,实现最高效率
- 🎨 所见即所得编辑器,操作简单易用
- 🖋 使用您的 Outlook 签名——无需额外设置,点击发送即可!
- 立即获取 Kutools for Excel!
最佳办公效率工具
| 🤖 | KUTOOLS AI 助手:基于以下内容革新数据分析:智能执行 | 生成代码| 创建自定义公式 | 数据分析及生成图表| 调用 Kutools Functions…… |
| 热门功能:查找、高亮或标记重复项 | 删除空白行 | 合并列或单元格且不丢失数据 | 不使用公式的四舍五入…… | |
| 高级 LOOKUP:多条件 VLookup | 多值 VLookup | 跨多工作表 VLookup | 模糊查找…… | |
| 高级下拉列表:快速创建下拉列表 | 级联下拉列表 | 多选下拉列表…… | |
| 列管理器:添加指定数量的列|移动列|切换隐藏列的可见性状态|比较区域与列…… | |
| 特色功能:网格聚焦 | 设计视图 |增强编辑栏 | 工作簿和表管理器 | 资源库(自动文本)| 日期提取 | 汇总工作表 | 加密/解密单元格 | 按列表发送邮件 | 超级筛选 | 特殊筛选(筛选粗体单元格/斜体/删除线……) ...... | |
| 精选 15 工具集:12 文本工具(添加文本,删除特定字符,……)| 50+ 图表 类型(甘特图,……)| 40+ 实用公式(基于生日计算年龄,……)| 19 插入工具(插入二维码,从路径插入图片,……)| 12 转换工具(小写金额转大写,汇率转换,……)| 7 合并和拆分工具(高级合并行,分割单元格,……)|……更多 |
使用 Kutools for Excel 大幅提升您的 Excel 技能,体验前所未有的高效。Kutools for Excel 提供 300 多项高级功能,助您提升生产力、节省时间。立即点击此处,获取您最需要的功能……
Office Tab 为 Office 带来标签式界面,让您的工作更轻松
- 在 Word、Excel、PowerPoint、Publisher、Access、Visio 和 Project 中启用标签式编辑和阅读。
- 在同一个窗口的新标签页中打开并创建多个文档,而非在新窗口中。
- 将您的工作效率提升 50%,每天减少数百次鼠标点击!
所有 Kutools 插件,一个安装程序
Kutools for Office 套件捆绑了适用于 Excel、Word、Outlook 和 PowerPoint 的插件以及 Office Tab Pro,非常适合需要跨多个 Office 应用高效协作的团队。
- 一体化套件— Excel、Word、Outlook 和 PowerPoint 插件 + Office Tab Pro
- 一个安装程序,一个许可证— 几分钟内完成设置(支持 MSI)
- 协同效果更佳— 在多个 Office 应用中实现高效协同
- 30 天全功能试用— 无需注册,无需信用卡
- 超值之选— 比单独购买插件更省钱