KutoolsforOffice — 一套方案,五大工具。事半功倍。

如何通过 Outlook 从 Excel 发送单元格区域或邮件?

作者Xiaoyang修改日期

您是否曾遇到过这样的困扰:完成工作表中的报告后,需要将包含重要数据的某个单元格区域发送给特定收件人?有没有一种快捷方法,无需打开 Outlook,就能直接从 Excel 发送该区域?

使用 VBA 代码从 Excel 以附件形式发送单元格区域

使用 VBA 代码从 Excel 以邮件正文形式发送单元格区域


蓝色右向箭头气泡 使用 VBA 代码从 Excel 以附件形式发送单元格区域

以下 VBA 代码可助您将所选区域作为附件从 Excel 中发送。请按以下步骤操作:

1. 打开您的工作簿,然后按住 ALT + F11 键,即可打开 Microsoft Visual Basic for Applications 窗口

2. 单击插入> 模块,并将以下代码粘贴到模块窗口中。

VBA 代码:从 Excel 以附件形式发送单元格区域

Sub SendRange()
'Update 20131209
Dim xFile As String
Dim xFormat As Long
Dim Wb As Workbook
Dim Wb2 As Workbook
Dim Ws As Worksheet
Dim FilePath As String
Dim FileName As String
Dim OutlookApp As Object
Dim OutlookMail As Object
Dim WorkRng As Range
xTitleId = "KutoolsforExcel"
Set WorkRng = Application.Selection
Set WorkRng = Application.InputBox("Range", xTitleId, WorkRng.Address, Type:=8)
Application.ScreenUpdating = False
Application.DisplayAlerts = False
Set Wb = Application.ActiveWorkbook
Wb.Worksheets.Add
Set Ws = Application.ActiveSheet
WorkRng.Copy Ws.Cells(1, 1)
Ws.Copy
Set Wb2 = Application.ActiveWorkbook
Select Case Wb.FileFormat
Case xlOpenXMLWorkbook:
    xFile = ".xlsx"
    xFormat = xlOpenXMLWorkbook
Case xlOpenXMLWorkbookMacroEnabled:
    If Wb2.HasVBProject Then
        xFile = ".xlsm"
        xFormat = xlOpenXMLWorkbookMacroEnabled
    Else
        xFile = ".xlsx"
        xFormat = xlOpenXMLWorkbook
    End If
Case Excel8:
    xFile = ".xls"
    xFormat = Excel8
Case xlExcel12:
    xFile = ".xlsb"
    xFormat = xlExcel12
End Select
FilePath = Environ$("temp") & "\"
FileName = Wb.Name & Format(Now, "dd-mmm-yy h-mm-ss")
Set OutlookApp = CreateObject("Outlook.Application")
Set OutlookMail = OutlookApp.CreateItem(0)
Wb2.SaveAs FilePath & FileName & xFile, FileFormat:=xFormat
With OutlookMail
    .To = "skyyang@extendoffice.com"
    .CC = ""
    .BCC = ""
    .Subject = "information of kte"
    .Body = "hello, please check and read this document. "
    .Attachments.Add Wb2.FullName
    .Send
End With
Wb2.Close
Kill FilePath & FileName & xFile
Set OutlookMail = Nothing
Set OutlookApp = Nothing
Ws.Delete
Application.DisplayAlerts = True
Application.ScreenUpdating = True
End Sub

注意:您可根据自身需求修改上述代码中的以下信息。

  • .To = "skyyang@extendoffice.com"
  • .CC = ""
  • .BCC = ""
  • 。Subject = "kte 信息“
  • 您好,请查收并仔细阅读此文档。

3. 然后按 F5 键运行此代码,系统将弹出提示框,提醒您选择要发送的单元格区域。参见截图:

用于选择数据区域的 VBA 代码

4. 然后单击确定,将弹出一个提示框;待进度条完成后,单击允许,指定的单元格区域便会以附件形式发送给收件人。

单击“允许”以将所选区域作为附件发送

kutools for excel AI 的截图

借助 KUTOOLS AI 解锁 Excel 的神奇功能

  • 智能执行:只需输入简单命令,即可执行单元格操作、分析数据并创建图表。
  • 自定义公式:生成量身定制的公式,助您优化工作流程!
  • VBA 编码:轻松编写并运行 VBA 代码。
  • 公式解析:轻松掌握复杂公式,一目了然!
  • 文本翻译:轻松打破电子表格中的语言障碍!
借助 AI 驱动的工具提升您的 Excel 能力。立即下载,体验前所未有的高效!

蓝色右向箭头气泡 使用 VBA 代码从 Excel 以邮件正文形式发送单元格区域

如果您希望将 Excel 中的特定单元格区域作为邮件正文的一部分发送,也可以使用以下 VBA 代码轻松实现。

1. 激活您的工作表,然后按住 ALT + F11 键,即可打开 Microsoft Visual Basic for Applications 窗口

2. 单击插入> 模块,并将以下代码粘贴到模块窗口中。

VBA 代码:从 Excel 以邮件正文形式发送单元格区域

Sub EmailRange()
'Update 20131209
Dim WorkRng As Range
On Error Resume Next
xTitleId = "KutoolsforExcel"
Set WorkRng = Application.Selection
Set WorkRng = Application.InputBox("Range", xTitleId, WorkRng.Address, Type:=8)
Application.ScreenUpdating = False
WorkRng.Select
ActiveWorkbook.EnvelopeVisible = True
With ActiveSheet.MailEnvelope
    .Introduction = "Please read this email."
    .Item.To = "skyyang@extendoffice.com"
    .Item.Subject = "information of kte"
    .Item.Send
End With
Application.ScreenUpdating = True
End Sub

注意:您可根据自身需求修改上述代码中的以下信息。

  • 。Introduction = “请阅读此邮件。“
  • .Item.To = "skyyang@extendoffice.com"
  • 。Item.Subject = "kte 信息“

3. 然后按下 F5 键运行此代码,系统将弹出提示框,提醒您选择要发送的单元格区域。

用于选择数据区域的 VBA 代码

4. 然后单击确定,将弹出一个提示框;待进度条完成后,单击允许,指定的单元格区域便会以邮件正文形式发送给收件人。

单击“允许”以将所选区域作为邮件正文发送

注意事项:

1. 这些代码仅在 Outlook 设为您的默认邮件程序时可用。

2. 发送当前工作表后,您可前往 Outlook 确认邮件是否已成功发出。


相关文章:

如何通过 Outlook 仅从 Excel 发送单个工作表?

如何通过 Outlook 从 Excel 发送当前工作簿?

最佳办公效率工具

🤖KUTOOLS AI 助手:基于以下内容革新数据分析:智能执行   |  生成代码|  创建自定义公式  |  数据分析及生成图表|  调用 Kutools Functions……
热门功能查找、高亮或标记重复项   |  删除空白行   |  合并列或单元格且不丢失数据   |  不使用公式的四舍五入……
高级 LOOKUP多条件 VLookup  |  多值 VLookup  |   跨多工作表 VLookup   |   模糊查找……
高级下拉列表快速创建下拉列表   |  级联下拉列表   |  多选下拉列表……
列管理器添加指定数量的列|移动列|切换隐藏列的可见性状态|比较区域与列……
特色功能网格聚焦   |  设计视图   |增强编辑栏   | 工作簿和表管理器   |  资源库(自动文本)|  日期提取   |  汇总工作表  |  加密/解密单元格   | 按列表发送邮件   |  超级筛选   |   特殊筛选(筛选粗体单元格/斜体/删除线……) ......
精选 15 工具集12 文本工具添加文本删除特定字符,……)|   50+ 图表 类型甘特图,……)|   40+ 实用公式基于生日计算年龄,……)|   19 插入工具插入二维码从路径插入图片,……)|   12 转换工具小写金额转大写汇率转换,……)|   7 合并和拆分工具高级合并行分割单元格,……)|……更多
在您的首选语言中使用 Kutools – 支持英语、西班牙语、德语、法语、中文及 40+ 种其他语言!

使用 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 应用高效协作的团队。

ExcelWordOutlookTabsPowerPoint
  • 一体化套件— Excel、Word、Outlook 和 PowerPoint 插件 + Office Tab Pro
  • 一个安装程序,一个许可证— 几分钟内完成设置(支持 MSI)
  • 协同效果更佳— 在多个 Office 应用中实现高效协同
  • 30 天全功能试用— 无需注册,无需信用卡
  • 超值之选— 比单独购买插件更省钱