使用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);
}
}

如果你觉得这篇文章对你有帮我,请我吃块糖吧~

最新文章

  1. Java_I/O输入输出_实现读取文件时出现一个表示读取进度的进度条。可以使用java.swing包提供的输入流类ProgressMonitorInputStream
  2. linux中Apache更Nginx环境配置教程
  3. 【面试】【Spring常见问题总结】【09】
  4. Windows Azure
  5. javascript计算字符串中出现最多的字符和个数
  6. 利用GCD实现单利模式的宏代码
  7. 由 System.arraycopy 引发的巩固:对象引用 与 对象 的区别
  8. 原根求解算法 &amp;&amp; NTT算法
  9. 2015年第六届蓝桥杯javaB组 试题 答案 解析
  10. 五一出门必备的手机APP神器 让你瞬间大开眼界
  11. Shell命令-文件及目录操作之cp、find
  12. Spring Boot Externalized Configuration
  13. nginx——限制上传文件的大小
  14. ThreadLocal ——android消息机制handler在非主线程创建not called Looper.prepare() 错误的原因
  15. LSP劫持症状及解决方案
  16. Android程序中有多个Activity时的可全部退出方法
  17. Unity3D笔记二十 多媒体与网络
  18. APACHE 禁止通过IP直接访问
  19. windows下sqli-labs的搭建及学习(POST篇)
  20. Timer的异常

热门文章

  1. Immutable集合
  2. test20180919 区间最大值
  3. pandas Timestamp的用法
  4. Ribbon Status Bar
  5. BAT编程
  6. SimpleSocket
  7. Hadoop之 Balancer平衡速度
  8. Java8 lam。。。表达式
  9. 监督学习(Supervised learning)
  10. cpu监控之二:dstat