Set Multiple Pivot Filters By Cell Value

RJW2809

New Member
Joined
Jun 17, 2018
Messages
2
Hi,

I'm wanting to set a pivot table to filter the results according to values set by which ever cell is selected in the main worksheet. There are three cell ranges which if selected will give differing results. Within the pivot table itself there are four fields which could be filtered but only one or two of them would be set with a value at any one time, the rest need to be (All). As other settings are changed this would then need to be reflected in the pivot settings.

Code:
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
If Selection.Count = 1 Then
'Part 1 (works fine) this sets two values based on the cell that is selected in the range and sets values that to be referenced in part 3
    If Not Intersect(Target, Range("AA16:AQ32")) Is Nothing Then
'Filter Values to be used
        Worksheets("FC_LocationExceptions").Range("O14").Value = Selection.Offset(0, 31).Value
        Worksheets("FC_LocationExceptions").Range("O15").Value = Selection.Offset(0, 51).Value
'Filter Fields to be used
        Worksheets("FC_LocationExceptions").Range("P14").Value = Range("U12")
        Worksheets("FC_LocationExceptions").Range("P15").Value = Range("U13")


'Part 2 (presume works as no error here) clears the pivot table filters
With Worksheets("FC_LocationExceptions").PivotTables("LocationExceptions")
.PivotFields("DailyBiasGroup").ClearAllFilters
.PivotFields("ReturnQtyGroup").ClearAllFilters
.PivotFields("ReturnValueGroup").ClearAllFilters
.PivotFields("ZeroReturnGroup").ClearAllFilters


'Part 3 (where I'm gettng an error) sets the 4 filter values to the results of the calculations in part 1.
'Any two of the fields will be set to (All) and the other two will have numeric values resulting from part 1.
'Which two are set to (All) and which have values will be variable depending on other selections in the sheet
.PivotFields("DailyBiasGroup").PivotFilters.Add Type:=xlCaptionEquals, Value1:=[V3].Value
.PivotFields("ReturnQtyGroup").PivotFilters.Add Type:=xlCaptionEquals, Value1:=[V4].Value
.PivotFields("ReturnValueGroup").PivotFilters.Add Type:=xlCaptionEquals, Value1:=[V5].Value
.PivotFields("ZeroReturnGroup").PivotFilters.Add Type:=xlCaptionEqualss, Value1:=[V6].Value
'The process potentially then repeats if a different cell range is selected but with the same intended results, however in the below two there would be three fields with a value of (All)
End With


    End If
If Selection.Count = 1 Then
    If Not Intersect(Target, Range("AA14:AQ14")) Is Nothing Then
        Worksheets("FC_LocationExceptions").Range("O14").Value = Selection.Offset(0, 31).Value
        Worksheets("FC_LocationExceptions").Range("O15").Value = Selection.Offset(0, 31).Value
        Worksheets("FC_LocationExceptions").Range("P14").Value = Range("U12")
        Worksheets("FC_LocationExceptions").Range("P15").Value = Range("U12")


With Worksheets("FC_LocationExceptions").PivotTables("LocationExceptions")
.PivotFields("DailyBiasGroup").ClearAllFilters
.PivotFields("ReturnQtyGroup").ClearAllFilters
.PivotFields("ReturnValueGroup").ClearAllFilters
.PivotFields("ZeroReturnGroup").ClearAllFilters


.PivotFields("DailyBiasGroup").PivotFilters.Add Type:=xlCaptionEquals, Value1:=[V3].Value
.PivotFields("ReturnQtyGroup").PivotFilters.Add Type:=xlCaptionEquals, Value1:=[V4].Value
.PivotFields("ReturnValueGroup").PivotFilters.Add Type:=xlCaptionEquals, Value1:=[V5].Value
.PivotFields("ZeroReturnGroup").PivotFilters.Add Type:=xlCaptionEqualss, Value1:=[V6].Value
End With


    End If
If Selection.Count = 1 Then
    If Not Intersect(Target, Range("Y16:Y32")) Is Nothing Then
        Worksheets("FC_LocationExceptions").Range("O14").Value = Selection.Offset(0, 51).Value
        Worksheets("FC_LocationExceptions").Range("O15").Value = Selection.Offset(0, 51).Value
        Worksheets("FC_LocationExceptions").Range("P14").Value = Range("U13")
        Worksheets("FC_LocationExceptions").Range("P15").Value = Range("U13")


With Worksheets("FC_LocationExceptions").PivotTables("LocationExceptions")
.PivotFields("DailyBiasGroup").ClearAllFilters
.PivotFields("ReturnQtyGroup").ClearAllFilters
.PivotFields("ReturnValueGroup").ClearAllFilters
.PivotFields("ZeroReturnGroup").ClearAllFilters


.PivotFields("DailyBiasGroup").PivotFilters.Add Type:=xlCaptionEquals, Value1:=[V3].Value
.PivotFields("ReturnQtyGroup").PivotFilters.Add Type:=xlCaptionEquals, Value1:=[V4].Value
.PivotFields("ReturnValueGroup").PivotFilters.Add Type:=xlCaptionEquals, Value1:=[V5].Value
.PivotFields("ZeroReturnGroup").PivotFilters.Add Type:=xlCaptionEqualss, Value1:=[V6].Value
End With


    End If
End If
End If
End If
End Sub

Any help would be much appreciated.
Thanks in advance,
RJW
 

Excel Facts

Ambidextrous Undo
Undo last command with Ctrl+Z or Alt+Backspace. If you use the Undo icon in the QAT, open the drop-down arrow to undo up to 100 steps.

Forum statistics

Threads
1,215,575
Messages
6,125,613
Members
449,238
Latest member
wcbyers

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top