1

我怀疑一张工作表可以有多个数据透视表吗?如果是这样,有没有办法在工作表中定义他们的名字?

我编写了以下代码来更新/刷新在不同工作表上定义的数据透视表,但出现以下错误:

 Dim objExcel1,strPathExcel1
 Dim objSheet1,objSheet2,objSheet3

 Set objExcel1 = CreateObject("Excel.Application")
 strPathExcel1 = "D:\AravoVB\Copy of Original    Scripts\CopyofGEWingtoWing_latest_dump_21112012.xls"

objExcel1.Workbooks.open(strPathExcel1)
Set objSheet1 = objExcel1.ActiveWorkbook.Worksheets("Business Process Matrix")
Set objSheet2 = objExcel1.ActiveWorkbook.Worksheets("Workflow Status Matrix")
Set objSheet3 = objExcel1.ActiveWorkbook.Worksheets("Business Hierarchy Martix")

objSheet1.PivotTables(1).PivotCache.Refresh
objSheet2.PivotTables(1).PivotCache.Refresh
objSheet3.PivotTables(1).PivotCache.Refresh

错误: 下标超出范围

你能帮我吗?

更新

我有以下格式的数据 Excel 表:

Name   Fruits    Condition of Fruits
=====  ======    ====================

Ram    Apple       Good

Jadu   Apple       Bad

Tina   Orange      Good

Ram    Orange      Good

Tina   Apple       Bad

Ram    Apple       Bad

Pivot 程序在同一个 excel 的另一张表中的输出,比如在 sheet(2) 中应该是这样的:

Name  Fruits   Condition of Fruits
====  ======   ===================
               Good       Bad    Total
               ====      =====  ======
Ram   Apple     1           1     2
Ram   Orange    1           0     1
Tina  Apple     0           1     1
Tina  Orange    1           0     1
jadu  Apple     0           1     1
===================================
Grand Total     3           3     6
===================================

上述格式需要存在于工作表 (2) 的 Excel 中,只要工作表 (1) 中包含源数据,如第一个表所示。

我希望使用 Excel 数据透视表概念创建宏程序。

您能否为上述 Pivot 创建建议任何代码设置?

谢谢

4

1 回答 1

3

您可以在一张工作表中拥有多个数据透视表。创建它们,然后右键单击它们,选择“数据透视表选项...”并查看/更改它们的名称。通常您不需要这样做,因为 Excel 会自动将表命名为 [PivotTable* N* ],其中N为 1、2、3、...

但是,如果您经常更改它们的外观(例如添加或删除列和/或行),则应避免在单个工作表中包含多个枢轴

编辑:回应您的评论...是的,您可以...在 Excel2010.VBA 中,相关对象/方法是

ActiveWorkbook.PivotCaches.Create(SourceType:=..., SourceData:= ..., Version:=...).CreatePivotTable TableDestination:=..., TableName:=..., DefaultVersion:=...

源数据通过 PivotCache 对象定义,目标数据通过串联的 CreatePivotTable 方法定义。

以后你用

ActiveSheet.PivotTables(...).PivotFields(...).Orientation and .position

ActiveSheet.PivotTables(...).AddDataField ...PivotFields(...), "header", xlSum

指定您的数据透视表设计。

最好是开始录制宏,创建数据透视表,停止录制器并检查生成的代码。

于 2012-12-17T11:14:21.120 回答