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

这篇博客介绍了如何利用EasyExcel结合Apache POI来设置Excel行隐藏。通过分析源码,作者发现设置隐藏实际上是将行高设为0。文章提供了自定义工具类`CustomRowHeightStyleStrategy`的代码示例,用于隐藏特定行,实现了动态隐藏表格最后一行的功能。

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);

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

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

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

在使用 EasyExcel 时,设置高(宽度)是 Excel 格式化的一部分,通常用于优化数据展示效果。EasyExcel 提供了灵活的 API 来实现对高的控制。可以通过自定义 `WriteHandler` 来设置高。 以下是实现设置宽的配置方法: ### 设置宽的具体实现 通过实现 `WriteHandler` 接口,可以在写入 Excel 文件时动态控制高。以下是一个示例代码,展示了如何为所有设置统一的高: ```java import com.alibaba.easyexcel.write.handler.WriteHandler; import com.alibaba.easyexcel.write.metadata.holder.WriteSheetHolder; import com.alibaba.easyexcel.write.metadata.holder.WriteTableHolder; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; public class CustomRowHeightWriteHandler implements WriteHandler { private final short rowHeight; public CustomRowHeightWriteHandler(short rowHeight) { this.rowHeight = rowHeight; } @Override public void beforeSheetCreate(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder) { } @Override public void afterSheetCreate(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder) { } @Override public void beforeRowCreate(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, Integer rowIndex, Integer relativeRowIndex, Boolean isHead) { } @Override public void afterRowCreate(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, Row row, Integer rowIndex, Integer relativeRowIndex, Boolean isHead) { row.setHeight(rowHeight); // 设置高[^3] } } ``` 在实际使用中,可以通过以下方式将该 `WriteHandler` 添加到 EasyExcel 的写入配置中: ```java import com.alibaba.easyexcel.EasyExcel; import java.util.List; public class ExcelWriter { public static void writeExcelWithCustomRowHeight(String filePath, List<?> dataList, List<List<String>> headList) { EasyExcel.write(filePath) .head(headList) .registerWriteHandler(new CustomRowHeightWriteHandler((short) 500)) // 设置高为 500[^3] .sheet("Sheet1") .doWrite(dataList); } } ``` ### 动态设置高 如果需要根据内容动态调整高,可以在 `afterRowCreate` 方法中添加逻辑,根据内单元格内容的长度或复杂度动态计算高值。例如: ```java @Override public void afterRowCreate(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, Row row, Integer rowIndex, Integer relativeRowIndex, Boolean isHead) { if (rowIndex > 0) { // 跳过表头 int maxContentLength = 0; for (int i = 0; i < row.getLastCellNum(); i++) { String cellValue = row.getCell(i) != null ? row.getCell(i).toString() : ""; maxContentLength = Math.max(maxContentLength, cellValue.length()); } short calculatedHeight = (short) (maxContentLength * 256); // 根据内容长度动态计算高 row.setHeight(calculatedHeight); } } ``` ### 注意事项 - 高的单位是 `short` 类型,通常以 1/20 字符宽度为单位。 - 如果需要更复杂的设置(如根据特定的内容调整高),可以扩展逻辑实现更细粒度的控制。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

睡竹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值