不同的数据透视表发送到不同的电子邮件 VBA
创始人
2025-01-08 19:00:55
0

以下是一个示例VBA代码,用于将不同的数据透视表发送到不同的电子邮件地址。

Sub SendPivotTablesByEmail()
    Dim wb As Workbook
    Dim ws As Worksheet
    Dim pt As PivotTable
    Dim rng As Range
    Dim wsEmail As Worksheet
    Dim rngEmail As Range
    Dim cell As Range
    Dim outlookApp As Object
    Dim outlookMail As Object
    
    ' 打开目标工作簿
    Set wb = Workbooks.Open("C:\路径\目标工作簿.xlsx")
    ' 设置目标工作表
    Set ws = wb.Worksheets("目标工作表")
    
    ' 遍历每个数据透视表
    For Each pt In ws.PivotTables
        ' 清除之前的筛选
        pt.ClearAllFilters
        
        ' 设置筛选条件(可根据需要修改)
        pt.PivotFields("字段1").CurrentPage = "条件1"
        pt.PivotFields("字段2").CurrentPage = "条件2"
        
        ' 将数据透视表复制到新工作簿
        pt.TableRange1.Copy
        Set rng = ThisWorkbook.Worksheets.Add().Range("A1")
        rng.PasteSpecial xlPasteValues
        
        ' 保存新工作簿并关闭
        rng.Parent.SaveAs "C:\路径\" & pt.Name & ".xlsx"
        rng.Parent.Close False
        
        ' 创建 Outlook 应用程序对象
        Set outlookApp = CreateObject("Outlook.Application")
        ' 创建新邮件
        Set outlookMail = outlookApp.CreateItem(0)
        
        ' 设置邮件主题和收件人地址(可根据需要修改)
        With outlookMail
            .Subject = "数据透视表: " & pt.Name
            .To = "收件人1@example.com"
            .CC = "抄送人@example.com"
            
            ' 正文内容(可根据需要修改)
            .Body = "请查阅附件中的数据透视表。"
            
            ' 添加附件
            .Attachments.Add "C:\路径\" & pt.Name & ".xlsx"
            
            ' 发送邮件
            .Send
        End With
        
        ' 删除附件文件
        Kill "C:\路径\" & pt.Name & ".xlsx"
    Next pt
    
    ' 关闭目标工作簿
    wb.Close False
    
    ' 清除对象引用
    Set outlookMail = Nothing
    Set outlookApp = Nothing
    Set rng = Nothing
    Set ws = Nothing
    Set wb = Nothing
End Sub

请确保以下操作:

  1. 将代码中的文件路径修改为目标工作簿的实际路径。
  2. 根据需要修改筛选条件、邮件主题、收件人地址等部分。
  3. 确保已启用 Outlook 应用程序。
  4. 请注意,此代码将逐个发送数据透视表的副本。如果数据透视表较大或数量较多,可能会影响性能和邮件服务器容量。

您可以将此代码复制并粘贴到 Excel 的 VBA 编辑器中(按 ALT + F11 打开)的模块中。之后,您可以通过运行 VBA 宏“SendPivotTablesByEmail”来执行代码。

相关内容

热门资讯

安卓换鸿蒙系统会卡吗,体验流畅... 最近手机圈可是热闹非凡呢!不少安卓用户都在议论纷纷,说鸿蒙系统要来啦!那么,安卓手机换上鸿蒙系统后,...
安卓系统拦截短信在哪,安卓系统... 你是不是也遇到了这种情况:手机里突然冒出了很多垃圾短信,烦不胜烦?别急,今天就来教你怎么在安卓系统里...
app安卓系统登录不了,解锁登... 最近是不是你也遇到了这样的烦恼:手机里那个心爱的APP,突然就登录不上了?别急,让我来帮你一步步排查...
安卓系统要维护多久,安卓系统维... 你有没有想过,你的安卓手机里那个陪伴你度过了无数日夜的安卓系统,它究竟要陪伴你多久呢?这个问题,估计...
windows官网系统多少钱 Windows官网系统价格一览:了解正版Windows的购买成本Windows 11官方价格解析微软...
安卓系统如何卸载app,轻松掌... 手机里的App越来越多,是不是感觉内存不够用了?别急,今天就来教你怎么轻松卸载安卓系统里的App,让...
怎么复制照片安卓系统,操作步骤... 亲爱的手机控们,是不是有时候想把自己的手机照片分享给朋友,或者备份到电脑上呢?别急,今天就来教你怎么...
安卓系统应用怎么重装,安卓应用... 手机里的安卓应用突然罢工了,是不是让你头疼不已?别急,今天就来手把手教你如何重装安卓系统应用,让你的...
iwatch怎么连接安卓系统,... 你有没有想过,那款时尚又实用的iWatch,竟然只能和iPhone好上好?别急,今天就来给你揭秘,怎...
安装了Anaconda之后找不... 在安装Anaconda后,如果找不到Jupyter Notebook,可以尝试以下解决方法:检查环境...