如何在Excel中将一系列单元格作为图像粘贴到邮件正文中?

网友投稿 145 2024-02-16

如何在Excel中将一系列单元格作为图像粘贴到邮件正文中?

从Excel发送电子邮件时,如果需要复制一定范围的单元格并将其作为图像粘贴到邮件正文中。 您如何处理此任务?

使用Excel中的VBA代码将一系列单元格作为图像粘贴到电子邮件正文中

使用Excel中的VBA代码将一系列单元格作为图像粘贴到电子邮件正文中

如何在Excel中将一系列单元格作为图像粘贴到邮件正文中?

惊人的! 在 Excel 中使用高效的选项卡,如 Chrome、Edge、Firefox 和 Safari! 每天节省50%的时间,并减少数千次鼠标单击!

可能没有其他好的方法可以解决您的问题,本文中的VBA代码可以为您提供帮助。 请这样做:

1。 启用要复制的工作表并将其粘贴为图像,按住 ALT + F11 键打开 Microsoft Visual Basic应用程序 窗口。

2。 点击 插页 > 模块,然后将以下代码粘贴到 模块 窗口。

VBA代码:将一系列单元格作为图像粘贴到电子邮件正文中:

Sub sendMail() Dim TempFilePath As String Dim xOutApp As Object Dim xOutMail As Object Dim xHTMLBody As String Dim xRg As Range On Error Resume Next Set xRg = Application.InputBox("Please select the data range:", "KuTools for Excel", Selection.Address, , , , , 8) If xRg Is Nothing Then Exit Sub With Application .Calculation = xlManual .ScreenUpdating = False .EnableEvents = False End With Set xOutApp = CreateObject("outlook.application") Set xOutMail = xOutApp.CreateItem(olMailItem) Call createJpg(ActiveSheet.Name, xRg.Address, "DashboardFile") TempFilePath = Environ$("temp") & "\" xHTMLBody = "<span LANG=EN>" _ & "<p class=style2><span LANG=EN><font FACE=Calibri SIZE=3>" _ & "Hello, this is the data range that you want:<br> " _ & "<br>" _ & "<img src=//cdn.extendoffice.com/cid:DashboardFile.jpg>" _ & "<br>Best Regards!</font></span>" With xOutMail .Subject = "" .HTMLBody = xHTMLBody .Attachments.Add TempFilePath & "DashboardFile.jpg", olByValue .To = " " .Cc = " " .Display End With End Sub Sub createJpg(SheetName As String, xRgAddrss As String, nameFile As String) Dim xRgPic As Range Dim xShape As Shape ThisWorkbook.Activate Worksheets(SheetName).Activate Set xRgPic = ThisWorkbook.Worksheets(SheetName).Range(xRgAddrss) xRgPic.CopyPicture With ThisWorkbook.Worksheets(SheetName).ChartObjects.Add(xRgPic.Left, xRgPic.Top, xRgPic.Width, xRgPic.Height) .Activate For Each xShape In ActiveSheet.Shapes xShape.Line.Visible = msoFalse Next .Chart.Paste .Chart.Export Environ$("temp") & "\" & nameFile & ".jpg", "JPG" End With Worksheets(SheetName).ChartObjects(Worksheets(SheetName).ChartObjects.Count).Delete Set xRgPic = Nothing End Sub
Copy

备注:在以上代码中,您可以根据需要更改正文内容和电子邮件地址。

3。 插入代码后,按 F5运行该代码的关键,将弹出一个对话框,提醒您选择要插入电子邮件正文的数据范围,如图所示,请参见屏幕截图:

4. 然后点击 OK 按钮和a 其它咨询/备注 显示窗口,所选数据范围已作为图像插入到主体中,请参见屏幕截图:

备注: 在里面 其它咨询/备注 窗口中,您还可以根据需要在“收件人”和“抄送”字段中更改正文内容和电子邮件地址。

5。 最后点击 提交 按钮发送此电子邮件。

备注:如果您需要从不同的工作表中粘贴多个范围,则以下VBA代码可以帮您一个忙:

首先,您应该选择要插入电子邮件正文中的多个范围作为图片,然后应用以下代码:

VBA代码:将多个单元格区域粘贴到电子邮件正文中作为图像:

Sub sendMail() Dim TempFilePath As String Dim xOutApp As Object Dim xOutMail As Object Dim xHTMLBody As String Dim xRg As Range Dim xSheet As Worksheet Dim xAcSheet As Worksheet Dim xFileName As String Dim xSrc As String On Error Resume Next TempFilePath = Environ$("temp") & "\RangePic\" If Len(VBA.Dir(TempFilePath, vbDirectory)) = False Then VBA.MkDir TempFilePath End If Set xAcSheet = Application.ActiveSheet For Each xSheet In Application.Worksheets xSheet.Activate Set xRg = xSheet.Application.Selection If xRg.Cells.Count > 1 Then Call createJpg(xSheet.Name, xRg.Address, "DashboardFile" & VBA.Trim(VBA.Str(xSheet.Index))) End If Next xAcSheet.Activate With Application .Calculation = xlManual .ScreenUpdating = False .EnableEvents = False End With Set xOutApp = CreateObject("outlook.application") Set xOutMail = xOutApp.CreateItem(olMailItem) xSrc = "" xFileName = Dir(TempFilePath & "*.*") Do While xFileName <> "" xSrc = xSrc + VBA.vbCrLf + "<img src=cid:" + xFileName + "><br>" xFileName = Dir If xFileName = "" Then Exit Do Loop xHTMLBody = "<span LANG=EN>" _ & "<p class=style2><span LANG=EN><font FACE=Calibri SIZE=3>" _ & "Hello, this is the data range that you want:<br> " _ & "<br>" _ & xSrc _ & "<br>Best Regards!</font></span>" With xOutMail .Subject = "" .HTMLBody = xHTMLBody xFileName = Dir(TempFilePath & "*.*") Do While xFileName <> "" .Attachments.Add TempFilePath & xFileName, olByValue xFileName = Dir If xFileName = "" Then Exit Do Loop .To = " " .Cc = " " .Display End With If VBA.Dir(TempFilePath & "*.*") <> "" Then VBA.Kill TempFilePath & "*.*" End If End Sub Sub createJpg(SheetName As String, xRgAddrss As String, nameFile As String) Dim xRgPic As Range ThisWorkbook.Activate Worksheets(SheetName).Activate Set xRgPic = ThisWorkbook.Worksheets(SheetName).Range(xRgAddrss) xRgPic.CopyPicture With ThisWorkbook.Worksheets(SheetName).ChartObjects.Add(xRgPic.Left, xRgPic.Top, xRgPic.Width, xRgPic.Height) .Activate .Chart.Paste .Chart.Export Environ$("temp") & "\RangePic\" & nameFile & ".jpg", "JPG" End With Worksheets(SheetName).ChartObjects(Worksheets(SheetName).ChartObjects.Count).Delete Set xRgPic = Nothing End Sub
Copy

最佳办公生产力工具

热门特色: 查找、突出显示或识别重复项   |  删除空白行   |  合并列或单元格而不丢失数据   | 不使用公式进行四舍五入 ... 超级查询: 多条件VLookup    多值VLookup  |   跨多个工作表的 VLookup   |   模糊查询 .... 高级下拉列表: 快速创建下拉列表   |  依赖下拉列表   |  多选下拉列表 .... 管理: 添加特定数量的列  |  移动列  |  切换隐藏列的可见性状态  |  比较范围和列 ... 特色功能: 网格焦点   |  设计图   |   大方程式酒吧    工作簿和工作表管理器   |  资源库 (自动文本)   |  日期选择器   |  合并工作表   |  加密/解密单元格    按列表发送电子邮件   |  超级筛选   |特殊过滤器 (过滤粗体/斜体/删除线...)...前 15 个工具集12 文本 工具 (添加文本, 删除字符,...)   |   50+ 图表 类型 (甘特图,...)   |   40+ 实用 公式 (根据生日计算年龄,...)   |   19 插入 工具 (插入二维码, 从路径插入图片,...)   |   12 转化 工具 (小写金额转大写, 货币兑换,...)   |   7 合并与拆分 工具 (高级组合行, 分裂细胞,...)   |   ... 和更多

使用 Kutools for Excel 增强您的 Excel 技能,体验前所未有的效率。 Kutools for Excel 提供了 300 多种高级功能来提高生产力并节省时间。  单击此处获取您最需要的功能...

阅读更多
Office Tab 为 Office 带来选项卡式界面,让您的工作更加轻松
在Word,Excel,PowerPoint中启用选项卡式编辑和阅读,发布者,Access,Visio和Project。 在同一窗口的新选项卡中而不是在新窗口中打开并创建多个文档。 每天将您的工作效率提高50%,并减少数百次鼠标单击!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:如何在Excel中保存或保留对ActiveX列表框的选择?
下一篇:如何在没有Outlook的Excel中发送电子邮件?
相关文章

 发表评论

暂时没有评论,来抢沙发吧~


×