Restituzione di un intervallo di valori tramite ICustomFunction
IlIFunzione personalizzata è deprecato dal rilascio di Aspose.Cells for Java 20.8. Si prega di utilizzare ilMotore di calcolo astratto classe. L’uso delMotore di calcolo astratto classe è descritta nel seguente articolo.
Restituzione di un intervallo di valori utilizzando AbstractCalculationEngine.
Aspose.Cells fornisceIFunzione personalizzatainterfaccia utilizzata per implementare funzioni definite dall’utente o personalizzate che non sono supportate da Microsoft Excel come funzioni predefinite.
Principalmente quando si implementa ilIFunzione personalizzata metodo di interfaccia, è necessario restituire un singolo valore di cella. Ma a volte è necessario restituire un intervallo di valori. Questo articolo spiegherà come restituire l’intervallo di valori daIFunzione personalizzata.
Restituzione di un intervallo di valori tramite ICustomFunction
Il codice seguente implementaIFunzione personalizzata e restituisce l’intervallo di valori tramite il suo metodo. Si prega di controllarefile excel di output ePDF generato con il codice per riferimento.
Crea una classe con una funzioneCalcola funzione personalizzata. Questa classe implementaIFunzione personalizzata.
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java | |
import java.util.ArrayList; | |
import com.aspose.cells.AbstractCalculationEngine; | |
import com.aspose.cells.CalculationData; | |
import com.aspose.cells.DateTime; | |
public class CustomFunctionStaticValue extends AbstractCalculationEngine { | |
@Override | |
public void calculate(CalculationData calculationData) { | |
calculationData.setCalculatedValue(new Object[][] { new Object[] { new DateTime(2015, 6, 12, 10, 6, 30), 2 }, | |
new Object[] { 3.0, "Test" } }); | |
} | |
} |
Ora usa la funzione sopra nel tuo programma.
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java | |
// The path to the documents directory. | |
String dataDir = Utils.getDataDir(ReturningRangeOfValues.class); | |
Workbook wb = new Workbook(); | |
Cells cells = wb.getWorksheets().get(0).getCells(); | |
Cell cell = cells.get(0, 0); | |
cell.setArrayFormula("=MYFUNC()", 2, 2); | |
Style style = cell.getStyle(); | |
style.setNumber(14); | |
cell.setStyle(style); | |
CalculationOptions copt = new CalculationOptions(); | |
copt.setCustomFunction(new CustomFunctionStaticValue()); | |
wb.calculateFormula(copt); | |
// Save to xlsx by setting the calc mode to manual | |
wb.getSettings().getFormulaSettings().setCalculationMode(CalcModeType.MANUAL); | |
wb.save(dataDir + "output.xlsx"); | |
// Save to pdf | |
wb.save(dataDir + "output.pdf"); | |