easyExcel设置行隐藏,解决setHidden(true)失效问题
easyexcel
快速、简洁、解决大文件内存溢出的java处理Excel工具
项目地址:https://gitcode.com/gh_mirrors/ea/easyexcel
免费下载资源
·
1、前言
easyExcel提供了一个方法,如下:
WriteCellStyle.setHidden(true);
设置单元格为隐藏样式
但是,这个方法并不生效!GitHub上也没有相应源码。。。能直接用这个方法实现的效果的朋友麻烦d一下
2、实现行隐藏原理
easyExcel底层是POI,因此,easyExcel设置隐藏样式,也是离不开POI的,在查看POI源码时,发现,设置行为隐藏样式,其实就是把行高设置为0,我们在Excel中也可以得知,隐藏行,其实行高就是为0,如下:
【第8行设置为隐藏,行高为0】
实现的原理:把需要隐藏的行,行高设置为0即可
3、代码如下
easyExcel可以通过如下代码,分别给表头和内容设置行高:
// 设置数据表格的行高 参数1表示表头行高,参数2表示内容行高
SimpleRowHeightStyleStrategy rowHeightStrategy3 = new SimpleRowHeightStyleStrategy((short)20, (short) 18);
但是,实际开发中,这个对象并不能满足我们的需求
例如:需要设置最后一行为隐藏时,这个类不能实现该效果
如果单独给哪一列设置为隐藏样式,可以加入自定义工具类,如下:
3.1、自定义行样式的工具类代码
package com.shuizhu.util;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.Row;
import com.alibaba.excel.write.style.row.AbstractRowHeightStyleStrategy;
/**
* excel表格的行高设置及样式
*
* @author 睡竹
*/
public class CustomRowHeightStyleStrategy extends AbstractRowHeightStyleStrategy {
/**
* 设置需要隐藏的行号
*/
Integer rowNum;
public CustomRowHeightStyleStrategy(int rowNum){
this.rowNum = rowNum;
}
/**
* 设置表头的行高
*/
@Override
protected void setHeadColumnHeight(Row row, int relativeRowIndex) {
//设置表头行高为18
row.setHeightInPoints(18);
}
/**
* 设置内容的行高 relativeRowIndex为行数,索引从0开始
*/
@Override
protected void setContentColumnHeight(Row row, int relativeRowIndex) {
if (relativeRowIndex + 1 == rowNum) {
//设置行隐藏
row.setHeightInPoints((0));
}
}
}
解释:
该类有2个关键点:
- rowNum:行号,需要给哪一行设置隐藏样式,我们就传递该行的序号就可以了,例如,我们表格数据一共5行【总行数是可以通过Java代码获取的】,需要把第5行隐藏,我们传递5就可以了
- relativeRowIndex:行号, protected void setContentColumnHeight方法会执行N次【N = 表格数据的总行数】
在构建表格时,传递对应的行数即可:
我隐藏了第5行,看下效果吧:
表格的第5行隐藏了!
GitHub 加速计划 / ea / easyexcel
31.64 K
7.47 K
下载
快速、简洁、解决大文件内存溢出的java处理Excel工具
最近提交(Master分支:2 个月前 )
c42183df
Bugfix 2 个月前
efa7dff6 * 重新加回 `commons-io`
2 个月前
更多推荐
已为社区贡献15条内容
所有评论(0)