当前位置:   article > 正文

easyExcel设置行隐藏,解决setHidden(true)失效问题_easyexcel隐藏列

easyexcel隐藏列

1、前言

easyExcel提供了一个方法,如下:

WriteCellStyle.setHidden(true);

设置单元格为隐藏样式

 但是,这个方法并不生效!GitHub上也没有相应源码。。。能直接用这个方法实现的效果的朋友麻烦d一下

2、实现行隐藏原理

easyExcel底层是POI,因此,easyExcel设置隐藏样式,也是离不开POI的,在查看POI源码时,发现,设置行为隐藏样式,其实就是把行高设置为0,我们在Excel中也可以得知,隐藏行,其实行高就是为0,如下:

【第8行设置为隐藏,行高为0】

 实现的原理:把需要隐藏的行,行高设置为0即可

3、代码如下

easyExcel可以通过如下代码,分别给表头和内容设置行高:

  1. // 设置数据表格的行高 参数1表示表头行高,参数2表示内容行高
  2. SimpleRowHeightStyleStrategy rowHeightStrategy3 = new SimpleRowHeightStyleStrategy((short)20, (short) 18);

但是,实际开发中,这个对象并不能满足我们的需求

例如:需要设置最后一行为隐藏时,这个类不能实现该效果

如果单独给哪一列设置为隐藏样式,可以加入自定义工具类,如下:

3.1、自定义行样式的工具类代码

  1. package com.shuizhu.util;
  2. import org.apache.poi.ss.usermodel.CellStyle;
  3. import org.apache.poi.ss.usermodel.Row;
  4. import com.alibaba.excel.write.style.row.AbstractRowHeightStyleStrategy;
  5. /**
  6. * excel表格的行高设置及样式
  7. *
  8. * @author 睡竹
  9. */
  10. public class CustomRowHeightStyleStrategy extends AbstractRowHeightStyleStrategy {
  11. /**
  12. * 设置需要隐藏的行号
  13. */
  14. Integer rowNum;
  15. public CustomRowHeightStyleStrategy(int rowNum){
  16. this.rowNum = rowNum;
  17. }
  18. /**
  19. * 设置表头的行高
  20. */
  21. @Override
  22. protected void setHeadColumnHeight(Row row, int relativeRowIndex) {
  23. //设置表头行高为18
  24. row.setHeightInPoints(18);
  25. }
  26. /**
  27. * 设置内容的行高 relativeRowIndex为行数,索引从0开始
  28. */
  29. @Override
  30. protected void setContentColumnHeight(Row row, int relativeRowIndex) {
  31. if (relativeRowIndex + 1 == rowNum) {
  32. //设置行隐藏
  33. row.setHeightInPoints((0));
  34. }
  35. }
  36. }

解释:

该类有2个关键点:

  1. rowNum:行号,需要给哪一行设置隐藏样式,我们就传递该行的序号就可以了,例如,我们表格数据一共5行【总行数是可以通过Java代码获取的】,需要把第5行隐藏,我们传递5就可以了
  2. relativeRowIndex:行号, protected void setContentColumnHeight方法会执行N次【N = 表格数据的总行数】

在构建表格时,传递对应的行数即可:

我隐藏了第5行,看下效果吧:

表格的第5行隐藏了! 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/170347
推荐阅读
相关标签
  

闽ICP备14008679号