【发布时间】:2020-12-16 11:54:25
【问题描述】:
我在我的 excel 文件中有一个包含 3 列(id、type、month)的工作表。
知道很多项目出现不止一次,我需要获取每个 id 每月的出现次数,然后获取 id 出现两次、出现 3 次的次数,...
有人告诉我,数据透视表是解决方案。所以我用宏记录器创建了一个数据透视表。当我尝试执行宏时,它向我发送错误 1004:无效引用。
这里是我的宏:
Sub Relivr()
'
Dim LastRow As Long
LastRow = ActiveWorkbook.Worksheets("Delivery").Range("A65536").End(xlUp).Row
'the error comes from this line
ActiveWorkbook.PivotCaches.Create(SourceType:=xlDatabase, SourceData:="'Delivery'!R1C1:R" & LastRow & "C4", Version:=xlPivotTableVersion12).CreatePivotTable TableDestination:="'Delivery'!R1C13", TableName:="Tableau croisé dynamique2", DefaultVersion:=xlPivotTableVersion12*
Sheets("Delivery").Select
Cells(1, 13).Select
With ActiveSheet.PivotTables("Tableau croisé dynamique2").PivotFields("ID")
.Orientation = xlRowField
.Position = 1
End With
With ActiveSheet.PivotTables("Tableau croisé dynamique2").PivotFields( _
"Month")
.Orientation = xlColumnField
.Position = 1
End With
ActiveSheet.PivotTables("Tableau croisé dynamique2").AddDataField ActiveSheet. _
PivotTables("Tableau croisé dynamique2").PivotFields("type"), _
"Nb delivries", xlCount
ActiveSheet.PivotTables("Tableau croisé dynamique2").RowGrand = False
Range("H3").Select
ActiveCell.FormulaR1C1 = "=COUNTIF(RC[6]:R[12342]C[6],""=2"")"
Range("H4").Select
ActiveCell.FormulaR1C1 = "=COUNTIF(R[-1]C[7]:R[12341]C[7],""=2"")"
End Sub
我正在使用 Office 2007
感谢任何和所有的帮助。
谢谢
【问题讨论】:
-
您必须为此使用 VBA 吗?仅使用数据透视表就可以非常轻松地制作这种表格 - 无需代码。
-
不幸的是,我必须将 vba 作为程序的一部分。