The maximum number of Cell Styles was exceeded. You can define up to 64000 style in a .xlsx Workbook

The maximum number of Cell Styles was exceeded. You can define up to 64000 style in a .xlsx Workbook 创建单元格样式时,有64000个单元格创建了单元格样式,导致报错

如题,创建单元格样式时,有64000个单元格创建了单元格样式,导致报错,网上对此问题回复大都是 “创建单元格放在for循环外面”,那一个实例的情况下但凡有一个单元格修改样式就会覆盖其它所有,显然是解决不了问题的。

这个关键点在于 workbook.createCellStyle();

看源码:
在这里插入图片描述
每次创建会计数,大于 MAXIMUM_STYLE_ID 这个常量就会抛异常

接着看CellStyle子类只有2个:
在这里插入图片描述
且都实现了 org.apache.poi.common.Duplicatable 接口
在这里插入图片描述
这里有个copy方法且子类都有实现,那么只需要创建一个实例然后copy(),跳过workbook.createCellStyle();的计数,就不会超出 MAXIMUM_STYLE_ID常量了

修改后代码:
在这里插入图片描述

稍加改造下就可以解决这个问题

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值