【问题标题】:Error 1004: invalid references when creating a pivot table with vba错误 1004:使用 vba 创建数据透视表时引用无效
【发布时间】: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 作为程序的一部分。

标签: excel vba


【解决方案1】:

有两种方法可以做到这一点:

  1. 正如您所说,数据透视表是显而易见的选择,但我不确定您为什么认为 VBA 会阻止您使用数据透视表?一旦掌握了窍门,在 VBA 中操作数据透视表就相对容易了——宏记录器对于学习对象模型的来龙去脉非常有用,或者 here 是入门教程。

  2. 或者,您可以使用 ADO 连接到数据并使用 SQL 查询来获取所需的信息。请注意,这需要在单独的工作表上对数据进行适当的格式化,但这可以作为程序的一部分进行管理。微软有a good guide to using ADO to query Excel data

【讨论】:

  • 感谢您的回复,只是我不知道如何从 vba 操作数据透视表。你能给我一个示例代码或一个链接,我可以找到如何做到这一点。
  • 我有一个快速的谷歌,虽然那里有很多“让你开始”的代码示例(我添加了一个链接),但实际上并没有一个好的端端教程。正如我所说,我学会了使用宏记录器,至少在这种情况下,它确实是一种很好的学习方式。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多