Группировать сводные поля в сводной таблице

Возможные сценарии использования

Microsoft Excel позволяет группировать сводные поля сводной таблицы. Когда к сводному полю относится большой объем данных, часто бывает полезно сгруппировать их по разделам. Aspose.Cells также предоставляет эту функцию с помощьюPivotTable.setManualGroupField() метод.

Группировать сводные поля в сводной таблице

Следующий пример кода загружаетобразец файла Excelи выполняет группировку по первому сводному полю, используяPivotTable.setManualGroupField() метод. Затем он обновляет и вычисляет данные сводной таблицы и сохраняет книгу каквыходной файл Excel. На снимке экрана показано влияние примера кода на пример файла Excel. Как видно на скриншоте, первое сводное поле теперь сгруппировано по месяцам и кварталам.

дело:изображение_альтернативный_текст

Образец кода

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java
//Load sample workbook
Workbook wb = new Workbook("sampleGroupPivotFieldsInPivotTable.xlsx");
//Access the second worksheet
Worksheet ws = wb.getWorksheets().get(1);
//Access the pivot table
PivotTable pt = ws.getPivotTables().get(0);
//Specify the start and end date time
DateTime dtStart = new DateTime(2008, 1, 1);//1-Jan-2018
DateTime dtEnd = new DateTime(2008, 9, 5); //5-Sep-2018
//Specify the group type list, we want to group by months and quarters
int[] groupTypeList = new int[2];
groupTypeList[0] = PivotGroupByType.MONTHS;
groupTypeList[1] = PivotGroupByType.QUARTERS;
//Apply the grouping on the pivot field
PivotField field = pt.getRowFields().get(0);
field.groupBy(dtStart, dtEnd, groupTypeList, 1, true);
//Refresh and calculate pivot table
pt.setRefreshDataFlag(true);
pt.refreshData();
pt.calculateData();
pt.setRefreshDataFlag(false);
//Save the output Excel file
wb.save("outputGroupPivotFieldsInPivotTable.xlsx");