Hutool工具类ExcelWriter导出excel列宽自适应问题解决(已解决报错问题) 置顶!
前言:
因为项目中需要使用到ExcelWriter导出excel的列宽自适应,下面为解决该问题的经过,希望可以对遇到同样问题的开发者有所帮助。
一、通过查询Hutool官方的api文档发现autoSizeColumn()方法
但是,在代码中使用该方法后,发现有时会失效。
二、通过搜索发现其他开发者使用Sheet强制转换为SXSSFSheet,后再调用改方法可以成功设置自适应。
SXSSFSheet sheet = (SXSSFSheet) writer.getSheet();
sheet.trackAllColumnsForAutoSizing();
writer.autoSizeColumnAll(); // 要在写出内容后调用
再次尝试使用后报错:
java.lang.ClassCastException: org.apache.poi.hssf.usermodel.HSSFSheet cannot be cast to org.apache.poi.xssf.streaming.SXSSFSheet
三、自定义方法
如下是第一版,但不全面,可能出现"java.lang.IllegalArgumentException,that is already written to disk."错误,点击看详情:
/**
* 自适应宽度(中文支持)
* @param sheet
* @param size 因为for循环从0开始,size值为 列数-1
*/
public static void setSizeColumn(Sheet sheet, int size) {
for (int columnNum = 0; columnNum <= size; columnNum++) {
int columnWidth = sheet.getColumnWidth(columnNum) / 256;
for (int rowNum = 0; rowNum <= sheet.getLastRowNum(); rowNum++) {
Row currentRow;
//当前行未被使用过
if (sheet.getRow(rowNum) == null) {
currentRow = sheet.createRow(rowNum);
} else {
currentRow = sheet.getRow(rowNum);
}
if (currentRow.getCell(columnNum) != null) {
Cell currentCell = currentRow.getCell(columnNum);
if (currentCell.getCellType() == XSSFCell.CELL_TYPE_STRING) {
int length = currentCell.getStringCellValue().getBytes().length;
if (columnWidth < length) {
columnWidth = length;
}
}
}
}
sheet.setColumnWidth(columnNum, columnWidth * 256);
}
}
上面版本,可能会有点问题,出现类似java.lang.IllegalArgumentException: Attempting to write a row[0] in the range [0,87] that is already written to disk.
这样的错误。
所以优化出最终版本(不考虑没获取到的行,避免和临时文档的冲突):
/**
* 自适应宽度(中文支持);设置所有列为自动宽度,不考虑合并单元格
*
* @param sheet sheet
* @param size 因为for循环从0开始,size值为 列数-1
*/
private static void setAutoSizeColumnAll(Sheet sheet, int size) {
for (int columnNum = 0; columnNum <= size; columnNum++) {
int columnWidth = sheet.getColumnWidth(columnNum) / 256;
for (int rowNum = 0; rowNum <= sheet.getLastRowNum(); rowNum++) {
Row currentRow = sheet.getRow(rowNum);
//当前行未被使用过
if (currentRow != null) {
if (currentRow.getCell(columnNum) != null) {
Cell currentCell = currentRow.getCell(columnNum);
if (currentCell.getCellType() == CellType.STRING) {
int length = currentCell.getStringCellValue().getBytes().length;
if (columnWidth < length) {
columnWidth = length;
}
}
}
}
}
sheet.setColumnWidth(columnNum, columnWidth * 256);
}
}
问题解决,可以实现列宽自适应。
标题:Hutool工具类ExcelWriter导出excel列宽自适应问题解决(已解决报错问题)
作者:mmzsblog
地址:https://www.mmzsblog.cn/articles/2025/03/14/1741923571431.html
如未加特殊说明,文章均为原创,转载必须注明出处。均采用CC BY-SA 4.0 协议!
本网站发布的内容(图片、视频和文字)以原创、转载和分享网络内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。若本站转载文章遗漏了原文链接,请及时告知,我们将做删除处理!文章观点不代表本网站立场,如需处理请联系首页客服。• 网站转载须在文章起始位置标注作者及原文连接,否则保留追究法律责任的权利。
• 公众号转载请联系网站首页的微信号申请白名单!
