java poi excel 富文本粗体无效

java poi excel 设置单元格富文本 粗体无效解决办法_poi 设置富文本-CSDN博客

问题描述

需求:java导出excel模板,单元格需要设置字段名+备注,字段名加粗,备注不加粗。

方案:可以采用富文本RichTextString来实现设置部分字体加粗样式。

效果:打开下载的xlsx模板表格,没有展示加粗效果,设置部分标红可以,加粗没有效果。

原因分析

网上查找资料,寻求帮助,看到上述博文,场景确实是wps打开无加粗效果,按照方案进行修改。

解决方案

尝试上述方案,验证成功,不过代码稍微有点不同,第一种是原博文的写法,第二种是最终采用的写法。

List<CTRElt> ctrEltList = hssfRichTextString.getCTRst().getRList();

if(ctrEltList != null && ctrEltList.size()>0){

for(CTRElt ctrElt : ctrEltList){

CTRPrElt ctrPrElt = ctrElt.getRPr();//获取属性元素

if(ctrPrElt != null){

List<CTBooleanProperty> bList = ctrPrElt.getBList();//获取<b/>元素

if(bList != null && bList.size() > 0){

bList.get(bList.size() - 1).unsetVal();//销毁设置的属性值

}

}

}

}


版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/xht1351549230/article/details/129934870

上述代码获取List存在报错,NoClassDefFoundError,改为如下数组写法:

CTRElt[] ctrEltArray = hssfRichTextString.getCTRst().getRArray();

if(ctrEltArray != null && ctrEltArray .length >0){

for(int i=0;i<ctrEltArray .length;i++){

CTRElt ctrElt = ctrEltArray[i];

CTRPrElt ctrPrElt = ctrElt.getRPr();//获取属性元素

if(ctrPrElt != null){

CTBooleanProperty[] bArray= ctrPrElt.getBArray();//获取<b/>元素

if(bArray!= null && bArray.length > 0){

bArray[bArray.length - 1].unsetVal();//销毁设置的属性值

}

}

}

}

总结

这类疑难杂症,还是对这块底层不了解,奇奇怪怪的问题,感谢大佬,小记一下积累经验,欢迎交流。

相关推荐
CodeCraft Studio6 小时前
Excel处理控件Aspose.Cells教程:使用 Python 将 Pandas DataFrame 转换为 Excel
python·json·excel·pandas·csv·aspose·dataframe
星空的资源小屋10 小时前
PPTist,一个完全免费的 AI 生成 PPT 在线网站
人工智能·python·电脑·excel
开开心心_Every10 小时前
免费语音合成工具:66种音色随心选
人工智能·面试·java-ee·计算机外设·电脑·maven·excel
偷心伊普西隆1 天前
EXCEL VBA 清空Excel工作表(Sheet)的方法
microsoft·excel
Coding_Doggy1 天前
苍穹外卖Day12 | Apache POI、导出Excel报表、HttpServletResponse、工作台
excel
l1t2 天前
张泽鹏先生手搓的纯ANSI处理UTF-8与美团龙猫调用expat库读取Excel xml对比测试
xml·人工智能·excel·utf8·expat
Source.Liu2 天前
【Python自动化】 21 Pandas Excel 操作完整指南
python·excel·pandas
会飞的小菠菜3 天前
如何根据Excel数据表生成多个合同、工作证、录取通知书等word文件?
word·excel·模板·数据表·生成文件
Access开发易登软件3 天前
Access开发导出PDF的N种姿势,你get了吗?
后端·低代码·pdf·excel·vba·access·access开发
課代表3 天前
VBA 中的 Excel 工作表函数
excel·vba·函数·对象·属性·range·静态变量