Прямой расчет пользовательской функции без записи ее на листе

Прямой расчет пользовательской функции без записи ее на листе

См. следующий пример кода, иллюстрирующий использование этого метода. Мы использовали пользовательскую функцию с именем*МояКомпания.ПользовательскаяФункция()*и мы вычисляем его значение как «Aspose.Cells». самостоятельно, а затем это значение автоматически объединяется со значением ячейки A1, которое является «Добро пожаловать в», с помощью механизма расчета, и окончательное вычисленное значение возвращается как «Добро пожаловать в Aspose.Cells». Как вы можете видеть в коде, мы не написали нашу пользовательскую функцию нигде на листе, и она вычисляется непосредственно с помощью нашей собственной пользовательской логики.

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java
public class CustomEngine extends AbstractCalculationEngine
{
// Override the Calculate method with custom logic
public void calculate(CalculationData data)
{
// Check the forumla name and calculate it yourself
if (data.getFunctionName().equals("MyCompany.CustomFunction"))
{
// This is our calculated value
data.setCalculatedValue("Aspose.Cells.");
}
}
}
public static void main(String[] args) throws Exception {
// Create a workbook
Workbook wb = new Workbook();
// Accesss first worksheet
Worksheet ws = wb.getWorksheets().get(0);
// Add some text in cell A1
ws.getCells().get("A1").putValue("Welcome to ");
// Create a calculation options with custom engine
CalculationOptions opts = new CalculationOptions();
opts.setCustomEngine(new CustomEngine());
// This line shows how you can call your own custom function without
// a need to write it in any worksheet cell
// After the execution of this line, it will return
// Welcome to Aspose.Cells.
Object ret = ws.calculateFormula("=A1 & MyCompany.CustomFunction()", opts);
// Print the calculated value on Console
System.out.println("Calculated Value: " + ret.toString());
}

Консольный вывод

Ниже приведен консольный вывод приведенного выше примера кода.

 Calculated Value: Welcome to Aspose.Cells.

Связанная статья