From e94feeee12d4356cf5e46b44894032b64f6d0110 Mon Sep 17 00:00:00 2001 From: Nick Burch Date: Mon, 9 May 2011 14:04:21 +0000 Subject: [PATCH] As Java doesn't allow static methods on interfaces, allow HSSFFormulaEvaluator or XSSFFormulaEvaluator to generically recalculate all formulas in a workbook git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1101033 13f79535-47bb-0310-9956-ffa450edef68 --- .../content/xdocs/spreadsheet/eval.xml | 6 +- .../hssf/usermodel/HSSFFormulaEvaluator.java | 72 ++++++++++++++----- .../poi/ss/formula/WorkbookEvaluator.java | 2 +- .../poi/ss/usermodel/FormulaEvaluator.java | 10 +++ .../org/apache/poi/ss/util/SheetUtil.java | 1 + .../xssf/usermodel/XSSFFormulaEvaluator.java | 42 +++++------ 6 files changed, 92 insertions(+), 41 deletions(-) diff --git a/src/documentation/content/xdocs/spreadsheet/eval.xml b/src/documentation/content/xdocs/spreadsheet/eval.xml index a0c9896ca0..b19517e061 100644 --- a/src/documentation/content/xdocs/spreadsheet/eval.xml +++ b/src/documentation/content/xdocs/spreadsheet/eval.xml @@ -197,7 +197,6 @@ if (cell!=null) {
Re-calculating all formulas in a Workbook - FileInputStream fis = new FileInputStream("/somepath/test.xls"); Workbook wb = new HSSFWorkbook(fis); //or new XSSFWorkbook("/somepath/test.xls") FormulaEvaluator evaluator = wb.getCreationHelper().createFormulaEvaluator(); @@ -212,6 +211,11 @@ for(int sheetNum = 0; sheetNum < wb.getNumberOfSheets(); sheetNum++) { } } + +

Alternately, if you know which of HSSF or XSSF you're working + with, then you can call the static + evaluateAllFormulaCells method on the appropriate + HSSFFormulaEvaluator or XSSFFormulaEvaluator class.

diff --git a/src/java/org/apache/poi/hssf/usermodel/HSSFFormulaEvaluator.java b/src/java/org/apache/poi/hssf/usermodel/HSSFFormulaEvaluator.java index 0250619c3d..86c85f02b3 100644 --- a/src/java/org/apache/poi/hssf/usermodel/HSSFFormulaEvaluator.java +++ b/src/java/org/apache/poi/hssf/usermodel/HSSFFormulaEvaluator.java @@ -17,21 +17,21 @@ package org.apache.poi.hssf.usermodel; -import java.util.Iterator; - +import org.apache.poi.ss.formula.CollaboratingWorkbooksEnvironment; +import org.apache.poi.ss.formula.IStabilityClassifier; +import org.apache.poi.ss.formula.WorkbookEvaluator; import org.apache.poi.ss.formula.eval.BoolEval; import org.apache.poi.ss.formula.eval.ErrorEval; import org.apache.poi.ss.formula.eval.NumberEval; import org.apache.poi.ss.formula.eval.StringEval; import org.apache.poi.ss.formula.eval.ValueEval; import org.apache.poi.ss.formula.udf.UDFFinder; -import org.apache.poi.ss.formula.CollaboratingWorkbooksEnvironment; -import org.apache.poi.ss.formula.IStabilityClassifier; -import org.apache.poi.ss.formula.WorkbookEvaluator; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellValue; import org.apache.poi.ss.usermodel.FormulaEvaluator; import org.apache.poi.ss.usermodel.Row; +import org.apache.poi.ss.usermodel.Sheet; +import org.apache.poi.ss.usermodel.Workbook; /** * Evaluates formula cells.

@@ -46,6 +46,7 @@ import org.apache.poi.ss.usermodel.Row; public class HSSFFormulaEvaluator implements FormulaEvaluator { private WorkbookEvaluator _bookEvaluator; + private HSSFWorkbook _book; /** * @deprecated (Sep 2008) HSSFSheet parameter is ignored @@ -55,9 +56,11 @@ public class HSSFFormulaEvaluator implements FormulaEvaluator { if (false) { sheet.toString(); // suppress unused parameter compiler warning } + this._book = workbook; } public HSSFFormulaEvaluator(HSSFWorkbook workbook) { this(workbook, null); + this._book = workbook; } /** * @param stabilityClassifier used to optimise caching performance. Pass null @@ -296,21 +299,52 @@ public class HSSFFormulaEvaluator implements FormulaEvaluator { * cells, and calling evaluateFormulaCell on each one. */ public static void evaluateAllFormulaCells(HSSFWorkbook wb) { - HSSFFormulaEvaluator evaluator = new HSSFFormulaEvaluator(wb); - for(int i=0; i rit = sheet.rowIterator(); rit.hasNext();) { - Row r = rit.next(); - - for (Iterator cit = r.cellIterator(); cit.hasNext();) { - Cell c = cit.next(); - if (c.getCellType() == HSSFCell.CELL_TYPE_FORMULA) - evaluator.evaluateFormulaCell(c); - } - } - } + evaluateAllFormulaCells(wb, new HSSFFormulaEvaluator(wb)); } + + /** + * Loops over all cells in all sheets of the supplied + * workbook. + * For cells that contain formulas, their formulas are + * evaluated, and the results are saved. These cells + * remain as formula cells. + * For cells that do not contain formulas, no changes + * are made. + * This is a helpful wrapper around looping over all + * cells, and calling evaluateFormulaCell on each one. + */ + public static void evaluateAllFormulaCells(Workbook wb) { + FormulaEvaluator evaluator = wb.getCreationHelper().createFormulaEvaluator(); + evaluateAllFormulaCells(wb, evaluator); + } + private static void evaluateAllFormulaCells(Workbook wb, FormulaEvaluator evaluator) { + for(int i=0; i @@ -46,6 +44,7 @@ import org.apache.poi.ss.usermodel.Sheet; public class XSSFFormulaEvaluator implements FormulaEvaluator { private WorkbookEvaluator _bookEvaluator; + private XSSFWorkbook _book; public XSSFFormulaEvaluator(XSSFWorkbook workbook) { this(workbook, null, null); @@ -59,9 +58,11 @@ public class XSSFFormulaEvaluator implements FormulaEvaluator { @Deprecated public XSSFFormulaEvaluator(XSSFWorkbook workbook, IStabilityClassifier stabilityClassifier) { _bookEvaluator = new WorkbookEvaluator(XSSFEvaluationWorkbook.create(workbook), stabilityClassifier, null); + _book = workbook; } private XSSFFormulaEvaluator(XSSFWorkbook workbook, IStabilityClassifier stabilityClassifier, UDFFinder udfFinder) { _bookEvaluator = new WorkbookEvaluator(XSSFEvaluationWorkbook.create(workbook), stabilityClassifier, udfFinder); + _book = workbook; } /** @@ -234,21 +235,22 @@ public class XSSFFormulaEvaluator implements FormulaEvaluator { * cells, and calling evaluateFormulaCell on each one. */ public static void evaluateAllFormulaCells(XSSFWorkbook wb) { - XSSFFormulaEvaluator evaluator = new XSSFFormulaEvaluator(wb); - for(int i=0; i rit = sheet.rowIterator(); rit.hasNext();) { - Row r = rit.next(); - - for (Iterator cit = r.cellIterator(); cit.hasNext();) { - XSSFCell c = (XSSFCell) cit.next(); - if (c.getCellType() == XSSFCell.CELL_TYPE_FORMULA) - evaluator.evaluateFormulaCell(c); - } - } - } + HSSFFormulaEvaluator.evaluateAllFormulaCells((Workbook)wb); } + /** + * Loops over all cells in all sheets of the supplied + * workbook. + * For cells that contain formulas, their formulas are + * evaluated, and the results are saved. These cells + * remain as formula cells. + * For cells that do not contain formulas, no changes + * are made. + * This is a helpful wrapper around looping over all + * cells, and calling evaluateFormulaCell on each one. + */ + public void evaluateAll() { + HSSFFormulaEvaluator.evaluateAllFormulaCells(_book); + } /** * Returns a CellValue wrapper around the supplied ValueEval instance.