使用Apache POI处理excel公式不更新的解决办法
2024-09-25 19:23:44
使用poi更新excel时,如果单元格A设置了公式,当其依赖的其他单元格填充了值之后,导出的excel中A仍为公式而不是自动计算的值,如图:
Paste_Image.png
分值小计没有更新成计算结果。
解决方法
poi中提供了org.apache.poi.ss.usermodel.FormulaEvaluator
这个接口,实现对公式的更新。其中HSSFFormulaEvaluator
, XSSFFormulaEvaluator
实现了这个接口。
实现思路
我们可以遍历一行单元格中的所有格,判断如果其类型为Cell.CELL_TYPE_FORMULA
,则证明此单元格为公式,可以使用evaluator.evaluateFormulaCell(cell);
将其更新。示例代码如下:
private static void updateFormula(Workbook wb,Sheet s,int row){
Row r=s.getRow(row);
Cell c=null;
FormulaEcaluator eval=null;
if(wb instanceof HSSFWorkbook)
eval=new HSSFFormulaEvaluator((HSSFWorkbook) wb);
else if(wb instanceof XSSFWorkbook)
eval=new XSSFFormulaEvaluator((XSSFWorkbook) wb);
for(int i=r.getFirstCellNum();i<r.getLastCellNum();i++){
c=r.getCell(i);
if(c.getCellType()==Cell.CELL_TYPE_FORMULA)
eval.evaluateFormulaCell(c);
}
}
如果你觉得这篇文章对你有帮我,请我吃块糖吧~
最新文章
- Java_I/O输入输出_实现读取文件时出现一个表示读取进度的进度条。可以使用java.swing包提供的输入流类ProgressMonitorInputStream
- linux中Apache更Nginx环境配置教程
- 【面试】【Spring常见问题总结】【09】
- Windows Azure
- javascript计算字符串中出现最多的字符和个数
- 利用GCD实现单利模式的宏代码
- 由 System.arraycopy 引发的巩固:对象引用 与 对象 的区别
- 原根求解算法 &;&; NTT算法
- 2015年第六届蓝桥杯javaB组 试题 答案 解析
- 五一出门必备的手机APP神器 让你瞬间大开眼界
- Shell命令-文件及目录操作之cp、find
- Spring Boot Externalized Configuration
- nginx——限制上传文件的大小
- ThreadLocal ——android消息机制handler在非主线程创建not called Looper.prepare() 错误的原因
- LSP劫持症状及解决方案
- Android程序中有多个Activity时的可全部退出方法
- Unity3D笔记二十 多媒体与网络
- APACHE 禁止通过IP直接访问
- windows下sqli-labs的搭建及学习(POST篇)
- Timer的异常