简体   繁体   English

Excel VBA-更改数据透视表的日期过滤器

[英]Excel VBA - Change date filter of a pivottable

I have a pivottable on my sheet and I'm trying to add a date filter: 我的工作表上有一个数据透视表,我想添加一个日期过滤器:

Private Sub foo()

Dim MyDate
MyDate = #1/27/1993#
Worksheets("Timeline").PivotTables("PivotTable7").PivotFields("EndDateFormatted").PivotFilters.Add Type:=xlBetween, Value1:=MyDate, Value2:=MyDate

End Sub

How ever this results in an "invalid procedure call or argument" error. 如何导致“无效的过程调用或参数”错误。 What am I doing wrong? 我究竟做错了什么?

Update: thx luke_t, now I know that I have to use xlDateBetween. 更新:thx luke_t,现在我知道我必须使用xlDateBetween。 Now my code looks like: 现在我的代码如下:

Private Sub foo()
    Dim d As Date
    Dim dd As Date

    d = DateSerial(2016, 1, 1)
    dd = DateSerial(2016, 1, 2)
    Worksheets("Timeline").PivotTables("PivotTable7").PivotFields("EndDateFormatted").PivotFilters.Add Type:=xlDateBetween, Value1:=d, Value2:=dd
End Sub

Now it says "the date you entered is not a valid date" (1004). 现在它显示“您输入的日期不是有效日期”(1004)。

You need to pass xlDateBetween into the Type:= parameter of the PivotFilters.Add method. 您需要将xlDateBetween传递到PivotFilters.Add方法的Type:=参数中。

Here is a list of constant names that can be passed into the type parameter. 这是可以传递给type参数的常量名称列表

Use a string with the Type:= parameter. 使用带有Type:=参数的字符串。 See below. 见下文。

Private Sub foo()
    Dim d As String

    d = "01/01/2016"
    Worksheets("Timeline").PivotTables("PivotTable7").PivotFields("EndDateFormatted").PivotFilters.Add Type:=xlDateBetween, Value1:=d, Value2:=d
End Sub

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM