Could not auto-size column. Make sure the column was tracked prior to auto-sizing the column.

SpringBoot-POI报错解决

Could not auto-size column. Make sure the column was tracked prior to auto-sizing the column.
翻译:无法自动调整列的大小。在自动调整列的大小之前,请确保已跟踪该列。

原因及解决:
在使用SXSSFSheet对象时,自动调整列宽的方法与XSSFSheet对象的不同。当调用autoSizeColumn()方法时,需要先调用trackAllColumnsForAutoSizing()方法来跟踪要自动调整宽度的所有列。否则,将会收到这个错误消息。

在使用循环自动调整多列宽度时,应该在循环体外调用 trackAllColumnsForAutoSizing() 方法,然后在循环体内调用 autoSizeColumn() 方法来逐个调整每列的宽度。

例如我的列宽自适应方法:

//默认列宽自适应,可限制最小列宽、最大列宽
private static void adaptiveColumnWidth(SXSSFSheet sheet, int columnCount, Integer minColumnWidth, Integer maxColumnWidth) {
    sheet.trackAllColumnsForAutoSizing();//跟踪要自动调整宽度的所有列
    for (int i = 0; i < columnCount; i++) {
        //设置列宽自适应
        sheet.autoSizeColumn(i);
        int currentColumnWidth = sheet.getColumnWidth(i);
        // 如果最小列宽不为null,且自适应列宽小于最小列宽,则设置该列宽为最小列宽
        if (minColumnWidth!=null && currentColumnWidth < (minColumnWidth * 256)) {
            sheet.setColumnWidth(i, minColumnWidth * 256);
        }
        // 如果最大列宽不为null,且自适应列宽大于最大列宽,则设置该列宽为最大列宽
        if (maxColumnWidth!=null && currentColumnWidth > (maxColumnWidth * 256)) {
            sheet.setColumnWidth(i, maxColumnWidth * 256);
        }
    }
}
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值