Вычисление формул с помощью Node.js через C++
Добавление формул и вычисление результатов
У Aspose.Cells встроен движок вычисления формул. Он может не только пересчитывать импортированные из шаблонов Excel формулы, но и поддерживает вычисление результатов добавленных формул в режиме выполнения.
Aspose.Cells поддерживает большинство формул или функций, характерных для Microsoft Excel (смотрите список поддерживаемых функций движком вычислений). Эти функции можно использовать через API или в дизайнерских таблицах. Aspose.Cells поддерживает большой набор математических, строковых, логических, дата/время, статистических, баз данных, поиска и ссылочных формул.
Используйте свойство getFormula() или методы setFormula(string, object) класса Cell для добавления формулы в ячейку. При применении формулы всегда начинайте строку с знака равенства (=), как при создании формулы в Microsoft Excel, и используйте запятую (,) для разделения параметров функции.
Чтобы вычислить результаты формул, пользователь может вызвать метод calculateFormula() класса Workbook, который обрабатывает все встроенные формулы в файле Excel. Или пользователь может вызвать метод calculateFormula(string) класса Worksheet, который обрабатывает все формулы внутри листа. Или пользователь может также вызвать метод calculate(CalculationOptions) класса Cell, который обрабатывает формулу одной ячейки:
const path = require("path");
const fs = require("fs");
const AsposeCells = require("aspose.cells.node");
// The path to the documents directory.
const dataDir = path.join(__dirname, "data");
// Instantiating a Workbook object
const workbook = new AsposeCells.Workbook();
// Adding a new worksheet to the Excel object
const sheetIndex = workbook.getWorksheets().add();
// Obtaining the reference of the newly added worksheet by passing its sheet index
const worksheet = workbook.getWorksheets().get(sheetIndex);
// Adding a value to "A1" cell
worksheet.getCells().get("A1").putValue(1);
// Adding a value to "A2" cell
worksheet.getCells().get("A2").putValue(2);
// Adding a value to "A3" cell
worksheet.getCells().get("A3").putValue(3);
// Adding a SUM formula to "A4" cell
worksheet.getCells().get("A4").setFormula("=SUM(A1:A3)");
// Calculating the results of formulas
workbook.calculateFormula();
// Get the calculated value of the cell
const value = worksheet.getCells().get("A4").getValue().toString();
// Saving the Excel file
workbook.save(path.join(dataDir, "output.xls"));
Важно знать о формулах
Прямое вычисление формулы
Aspose.Cells имеет встроенный механизм расчета формул. Кроме того, в Aspose.Cells можно вычислять результаты формул непосредственно, импортированных из файла дизайнера.
Иногда нужно вычислить результаты формул напрямую, не добавляя их в лист. Значения ячеек, используемых в формуле, уже существуют в листе, и все, что нужно — это найти результат этих значений на основе формулы Microsoft Excel без добавления самой формулы в лист.
Можно использовать API движка вычислений формул Aspose.Cells для Worksheet для получения результатов таких формул без добавления их в лист:
const path = require("path");
const AsposeCells = require("aspose.cells.node");
// The path to the documents directory.
const dataDir = path.join(__dirname, "data");
// Create a workbook
const workbook = new AsposeCells.Workbook();
// Access first worksheet
const worksheet = workbook.getWorksheets().get(0);
// Put 20 in cell A1
const cellA1 = worksheet.getCells().get("A1");
cellA1.putValue(20);
// Put 30 in cell A2
const cellA2 = worksheet.getCells().get("A2");
cellA2.putValue(30);
// Calculate the Sum of A1 and A2
const results = worksheet.calculateFormula("=Sum(A1:A2)");
// Print the output
console.log("Value of A1: " + cellA1.getStringValue());
console.log("Value of A2: " + cellA2.getStringValue());
console.log("Result of Sum(A1:A2): " + results.toString());
Приведенный выше код производит следующий вывод:
Value of A1: 20
Value of A2: 30
Result of Sum(A1:A2): 50.0
Как рассчитать формулы повторно
Если в рабочей книге много формул и необходимо повторно вычислять их при изменении только части, может быть полезно включить цепочку вычислений формул: formulaSettings.getEnableCalculationChain().
const path = require("path");
const AsposeCells = require("aspose.cells.node");
// The path to the documents directory.
const dataDir = path.join(__dirname, "data");
// Load the template workbook
const workbook = new AsposeCells.Workbook(path.join(dataDir, "book1.xls"));
// Print the time before formula calculation
console.log(new Date());
// Set the CreateCalcChain as true
workbook.getSettings().getFormulaSettings().setEnableCalculationChain(true);
// Calculate the workbook formulas
workbook.calculateFormula();
// Print the time after formula calculation
console.log(new Date());
// Change the value of one cell
workbook.getWorksheets().get(0).getCells().get("A1").putValue("newvalue");
// Re-calculate those formulas which depend on cell A1
workbook.calculateFormula();
Важно знать
Продвинутые темы
- Добавление ячеек в окно наблюдения формул Microsoft Excel
- Вычисление функции IFNA с помощью Aspose.Cells
- Расчет массивной формулы таблиц данных
- Расчет функций MINIFS и MAXIFS Excel 2016
- Уменьшение времени вычисления метода Cell.calculate
- Обнаружение циклических ссылок
- Прямой расчет пользовательской функции без записи ее на лист
- Реализация пользовательского расчетного механизма для расширения расчетного механизма по умолчанию Aspose.Cells
- Прерывание или отмена расчета формул книги
- Возвращение диапазона значений с использованием абстрактного расчетного механизма
- Установка режима расчета формул книги
- Использование функции FormulaText в Aspose.Cells