感觉 sheet.setDefaultColumnStyle 存在 bug

场景是已经有模板,有表头,获取模板后还需要动态增加一些表头,在使用 org.apache.poi 的包导出 excel 的时候,我用了 sheet.setDefaultColumnStyle 来设置动态表头整列的格式为文本,这个也是参考了网上的很多办法,但是一直没生效

java 复制代码
Sheet sheet = workbook.getSheetAt(0);
Row headRow = sheet.getRow(1);

CellStyle headStyle = workbook.createCellStyle();
headStyle.setAlignment(HorizontalAlignment.CENTER);
headStyle.setVerticalAlignment(VerticalAlignment.CENTER);

// 以下是网上找到的办法
// CellStyle textCellStyle = workbook.createCellStyle();
// textCellStyle.setDataFormat(STRING_FORMAT);
// 设置整列为文本格式 防止读取异常
// DataFormat textDataFormat = workbook.createDataFormat();
// headStyle.setDataFormat(textDataFormat.getFormat("@"));

int index = 15;
for (DynamicFieldConf conf : configList) {  // DynamicFieldConfResp 是我自己的动态累
    sheet.setColumnWidth(index, 5120);
    sheet.setDefaultColumnStyle(index, textCellStyle);   // 这个可能是工具的bug,没有生效 后面考虑优化
    Cell cell = headRow.createCell(index);
    cell.setCellStyle(headStyle);
    cell.setCellType(CellType.STRING);
    // cell.setCellType(Cell.CELL_TYPE_STRING);
    if (conf .getMust() == 1) {
        cell.setCellValue("*" + conf .getName());
    } else {
        cell.setCellValue(conf .getName());
    }
    index ++;
}

后来我妥协了,我想了另外一个愚蠢的办法,就是事先在模板上将固定表头后面的其他很多列先手动将单元格格式设置成文本,然后再去读取渲染动态表头,但是其实如果直接动态从0到1生成一个 excel 上面的代码还是有效果的,所以我怀疑是因为我读取了现有的 excel 再去动态生成,也不知道是不是

相关推荐
花间相见1 分钟前
【JAVA基础03】—— JDK、JRE、JVM详解及原理
java·开发语言·jvm
勿芮介3 分钟前
【大模型应用】在window/linux上卸载OpenClaw
java·服务器·前端
kuntli5 分钟前
Java内部类四种类型解析
java
闻哥25 分钟前
深入剖析Redis数据类型与底层数据结构
java·jvm·数据结构·spring boot·redis·面试·wpf
虾..27 分钟前
Linux 基于TCP实现服务端客户端通信(多进程/多线程版)
java·服务器·tcp/ip
星辰_mya30 分钟前
CompletableFuture:异步编程的“智能机械臂”
java·开发语言·面试
一见35 分钟前
WorkBuddy安装Skill的方法
android·java·javascript
悟空码字40 分钟前
SpringBoot + 腾讯地图实战:打造全能型地理位置服务平台,开箱即用!
java·spring boot·后端
小光学长42 分钟前
基于ssm的书法学习交流系统25ki07v1(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·开发语言·数据库·学习·ssm
金智维科技官方43 分钟前
Agent架构综述:从Prompt到Context
java·微服务·架构·agent