隐藏Excel工作簿中的第一个工作表,其中包含使用Apache POI生成的数据透视表



我使用 Apache POI 生成了一个包含 6 张工作表的工作簿,其中 3 张带有数据透视表,其余 3 张是这些数据透视表的数据源。

Sheet 1 -> Data1
Sheet 2 -> PivotTable_Data1
Sheet 3 -> Data2
Sheet 4 -> PivotTable_Data2
Sheet 5 -> Data3
Sheet 6 -> PivotTable_Data3

带有"数据透视表"的工作表名称保存数据透视表。

我要求隐藏数据表,以便生成的工作簿仅显示数据透视表表,并且用户可以根据需要取消隐藏数据表。

我使用下面的代码来隐藏工作表。

workbook.setSheetVisibility(workbook.getSheetIndex(sheet),SheetVisibility.HIDDEN);

无论我如何尝试,我都无法单独隐藏工作表 1,这适用于工作表 3 和 5。

我认为这可能是由于无法隐藏活动工作表的事实。考虑到这一点,我尝试将工作表 2 设置为选定的工作表/活动选项卡,但这破坏了数据透视表。

我知道SheetVisibility.VERY_HIDDEN但我确信这会给用户带来恐慌,因为它需要启用开发人员模式才能取消隐藏工作表。

我怎样才能做到这一点?

要解决此类问题,请在Excel中呈现数据透视表时阅读错误消息。我怀疑是:"无法在组编辑模式下编辑数据透视表"。 这意味着某些工作表被分组(同时选择(。如果要将第二个工作表设置为活动工作表,并且不取消选择第一个工作表,则会出现这种情况。然后选择两个工作表。

所以做:

workbook.getSheetAt(0).setSelected(false);
workbook.setActiveSheet(1);
...
workbook.setSheetVisibility(workbook.getSheetIndex(sheet),SheetVisibility.HIDDEN);

在组编辑模式下呈现数据透视表失败的背景:

如果对多个工作表进行分组(同时选择(,则其中一个分组工作表中的所有更改也会转到所有选定的工作表。因此,更改单元格内容的数据透视表的呈现也会更改其他工作表中的单元格内容。不过,这失败了。

最新更新