不同的数据透视表发送到不同的电子邮件 VBA
创始人
2025-01-08 19:00:24
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”来执行代码。

相关内容

热门资讯

透视真的!htx矩阵wepok... 透视真的!htx矩阵wepoker辅助,wepoker怎么挂飞机(透视)德州教程(有挂规律)1、下载...
透视真的!wepoker手机插... 透视真的!wepoker手机插件,wepoker轻量版透视方法(透视)2025新版教程(有挂插件)1...
透视挂透视!wepoker透视... 透视挂透视!wepoker透视破解版,wepoker游戏下载(透视)教你教程(有挂插件)1、wepo...
透视存在!we-poker辅助... 透视存在!we-poker辅助,we-poker软件(透视)AI教程(有挂攻略)1)we-poker...
透视安装!wepoker怎么发... 透视安装!wepoker怎么发冤家牌,wepoker模拟器哪个好用(透视)AI教程(有挂脚本)透视安...
透视系统!wepoker怎么挂... 透视系统!wepoker怎么挂飞机,wepoker俱乐部辅助(透视)微扑克教程(有挂黑科技)1、下载...
透视能赢!wepoker私人局... 透视能赢!wepoker私人局俱乐部,wepoker免费透视脚本(透视)教你攻略(有挂攻略)1、每一...
透视了解!wepoker透视底... 透视了解!wepoker透视底牌脚本,wepoker有没有辅助(透视)教你教程(有挂细节);1.we...
透视讲解!wejoker透视方... 透视讲解!wejoker透视方法,wepoker透视破解版(透视)wepoke教程(有挂辅助)1)w...
透视美元局!wepoker安装... 透视美元局!wepoker安装教程,wepoker手机版辅助(透视)AI教程(有挂插件);1、全新机...