使用poi更新excel时,如果单元格A设置了公式,当其依赖的其他单元格填充了值之后,导出的excel中A仍为公式而不是自动计算的值,如图:
分值小计没有更新成计算结果。
解决方法
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);
}
}