New to VBA and I am having difficulty with my Macro creating a pivot table on the same worksheet with my data (for example, starting the pivot table in the "I1" column). I have been able to run the macro to select all of the data within the sheet and then create this data on another worksheet. Since I will need to loop through a number of worksheets on the same workbook to create multiple pivot tables, having separate sheets isn't feasible.
Each worksheet has the same number of columns with a varying number of rows. My goal is to have this macro look at each worksheet and output a pivot table next to it.
I feel like the macro I have below is not referencing the correct pivot Table destination. Any assistance would be appreciated.
Sub Macro4() ' 'Macro4 Macro ' ' FinalRow = Cells(Rows.Count, 1).End(xlUp).Row DataSheet = ActiveSheet.Name ActiveWorkbook.PivotCaches.Create(SourceType:=xlDatabase, SourceData:= _ DataSheet & "!R1C1:R" & FinalRow & "C8", Version:=xlPivotTableVersion15). _ CreatePivotTable TableDestination:=DataSheet & "!R1C9", TableName:= _ "PivotTable4", DefaultVersion:=xlPivotTableVersion15 Sheets(DataSheet).Select Cells(1, 9).Select With ActiveSheet.PivotTables("PivotTable4").PivotFields("Document Type") .Orientation = xlRowField.Position = 1 End With With ActiveSheet.PivotTables("PivotTable4").PivotFields("Accounting Event") .Orientation = xlRowField.Position = 2 End With With ActiveSheet.PivotTables("PivotTable4").PivotFields("Document Number") .Orientation = xlRowField.Position = 3 End With ActiveSheet.PivotTables("PivotTable4").AddDataField ActiveSheet.PivotTables ( _"PivotTable4").PivotFields("Amount"), "Sum of Amount", xlSum End Sub
ActiveWorkbook.PivotCaches.Create(SourceType:=xlDatabase, SourceData:= _ DataSheet & "!R1C1:R" & FinalRow & "C8", Version:=xlPivotTableVersion15). _ CreatePivotTable TableDestination:=DataSheet & "!R1C9", TableName:= _ "PivotTable4", DefaultVersion:=xlPivotTableVersion15 Sheets(DataSheet).Select- Why are you trying to select it? I think the format of the TableDestination is off..Selectsomething? Does that line work for you at all, I'd think it'd throw an error. I recommend instead, first creating aRangevariable to store the destination, then just use that in theTableDestination:=part (i.e.TableDestination := myDest)...PivotFields("Document Type") .Orientationhas a space, for instance).