感觉 sheet.setDefaultColumnStyle 存在 bug

news/2024/7/21 4:20:14 标签: java, excel

场景是已经有模板,有表头,获取模板后还需要动态增加一些表头,在使用 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 再去动态生成,也不知道是不是


http://www.niftyadmin.cn/n/5369803.html

相关文章

Orange3数据转换(数据采样组件)

组件介绍: 固定数据比例(Fixed proportion of data) 返回整个数据的选定百分比 固定样本量(Fixed sample size) 返回选定数量的数据实例,并可以设置 Sample with replacement(替换样本),该替换样本始终从整个数据集中…

C语言小游戏:贪吃蛇(游戏开发的环境和功能介绍)

❀❀❀ 文章由不准备秃的大伟原创 ❀❀❀ ♪♪♪ 若有转载,请联系博主哦~ ♪♪♪ ❤❤❤ 致力学好编程的宝藏博主,代码兴国!❤❤❤ 生命不停,学习不止。铁汁们,我是大伟,欢迎来到大伟的游戏时间&#xff0c…

双非本科准备秋招(19.1)—— Synchronized优化

轻量级锁 流程 一个对象虽然有多线程加锁,但是加锁时间是错开的,那么可以用轻量级锁优化。 语法还是synchronized,只是对使用者是透明的。 static final Object obj new Object(); public static void method1() {synchronized( obj ) {//…

Three.js学习7:dat.GUI 参数控制

每个学 Three.js 的都被安利了 dat.GUI 吧? 我也不例外! 今天就来了学习下 dat.GUI,并记录下来自己的学习成果。 一、什么是 dat.GUI? dat.GUI 是一个轻量级的图形用户界面库(GUI 组件),使用这个库可以…

隐私计算技术创新赋能金融数字化转型

文章目录 前言一、金融数据要素流通和价值发挥面临的挑战二、隐私计算技术助推金融场景建设向纵深发展(一)基于可验证秘密共享算法的跨机构数据联合统计(二)基于联邦半监督学习的沉睡客户挖掘模型(三)基于跨域数据校验算法的客户信息准确性验证(四)基于异构隐私计算平台…

编译原理实验1——词法分析(python实现)

文章目录 实验目的实现定义单词对应的种别码定义输出形式:三元式python代码实现运行结果检错处理 总结 实验目的 输入一个C语言代码串,输出单词流,识别对象包含关键字、标识符、整型浮点型字符串型常数、科学计数法、操作符和标点、注释等等。…

BUUCTF-Real-[Tomcat]CVE-2017-12615

目录 漏洞描述 一、漏洞编号:CVE-2017-12615 二、漏洞复现 get flag 漏洞描述 CVE-2017-12615:远程代码执行漏洞 影响范围:Apache Tomcat 7.0.0 - 7.0.79 (windows环境) 当 Tomcat 运行在 Windows 操作系统时,且启用了 HTTP P…

MySQL用心总结

大家好,好久不见,今天笔者用心一步步写一份mysql的基础操作指南,欢迎各位点赞收藏 -- 启动MySQL net start mysql-- 创建Windows服务 sc create mysql binPath mysqld_bin_path(注意:等号与值之间有空格) mysql -h 地址 -…