カスタム計算エンジンを実装して、Aspose.Cells のデフォルト計算エンジンを拡張します

カスタム計算エンジンの実装

次のコードは、カスタム計算エンジンを実装します。インターフェースを実装しますAbstractCalculationEngineメソッドが 1 つしかない[calculate(CalculationDataデータ)](https://reference.aspose.com/cells/java/com.aspose.cells/abstractcalculationengine#calculate(com.aspose.cells.CalculationData))。このメソッドは、すべての数式に対して呼び出されます。このメソッド内で、したがって、Aspose.Cells の計算値が 20 の場合、カスタム エンジンは 30 を加算して 50 にします。

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java
public class CustomEngine extends AbstractCalculationEngine {
public void calculate(CalculationData data) {
if (data.getFunctionName().toUpperCase().equals("TODAY")) {
data.setCalculatedValue(CellsHelper.getDoubleFromDateTime(DateTime.getNow(), false) + 1.0);
}
}
public getProcessBuiltInFunctions() { return true; }
}
public static void main(String[] args) throws Exception {
// The path to the documents directory.
String dataDir = Utils.getDataDir(ImplementCustomCalculationEngine.class);
Workbook workbook = new Workbook();
Worksheet sheet = workbook.getWorksheets().get(0);
Cell a1 = sheet.getCells().get("A1");
Style style = cell.getStyle();
style.setNumber(14);
cell.setStyle(style);
a1.setFormula("=TODAY()");
// Without Custom Engine, the value of cell A1 will be 20
workbook.calculateFormula();
System.out.println("Without Custom Engine Value of A1: " + a1.getStringValue());
// With Custom Engine, the value of cell A1 will be 50
CalculationOptions opts = new CalculationOptions();
opts.setCustomEngine(new CustomEngine());
workbook.calculateFormula(opts);
System.out.println("With Custom Engine Value of A1: " + a1.getStringValue());
}

コンソール出力

上記のサンプル コードのコンソール出力を次に示します。

 Without Custom Engine Value of A1: 20

With Custom Engine Value of A1: 50

関連記事