ICustomFunctionを使用して値の範囲を返す
ICustomFunctionはAspose.Cells for Java 20.8のリリース以降非推奨となりました。代わりにAbstractCalculationEngineクラスを使用してください。AbstractCalculationEngineクラスの使用方法については、次の記事で説明しています。
Aspose.Cellsは、Microsoft Excelの組み込み関数としてサポートされていないユーザー定義またはカスタム関数を実装するために使用されるICustomFunctionインターフェースを提供します。
ICustomFunctionインターフェースのメソッドを実装する場合、通常は単一のセル値を返す必要があります。ただし、場合によっては値の範囲を返す必要があります。この記事では、ICustomFunctionから値の範囲を返す方法について説明します。
次のコードは、ICustomFunction を実装し、そのメソッドを通じて値の範囲を返します。
関数CalculateCustomFunctionを持つクラスを作成します。このクラスではICustomFunctionを実装します。
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET | |
public class CustomFunctionStaticValue : ICustomFunction | |
{ | |
public object CalculateCustomFunction(string functionName, ArrayList paramsList, ArrayList contextObjects) | |
{ | |
return new object[][] { | |
new object[]{new DateTime(2015, 6, 12, 10, 6, 30), 2}, | |
new object[]{3.0, "Test"} | |
}; | |
} | |
} |
上記の関数をプログラムで使用する
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET | |
// The path to the documents directory. | |
string dataDir = RunExamples.GetDataDir(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); | |
// Create workbook | |
Workbook wb = new Workbook(); | |
Cells cells = wb.Worksheets[0].Cells; | |
// Set formula | |
Cell cell = cells[0, 0]; | |
cell.SetArrayFormula("=MYFUNC()", 2, 2); | |
Style style = cell.GetStyle(); | |
style.Number = 14; | |
cell.SetStyle(style); | |
// Set calculation options for formula | |
CalculationOptions copt = new CalculationOptions(); | |
copt.CustomEngine = new CustomFunctionStaticValue(); | |
wb.CalculateFormula(copt); | |
// Save to xlsx by setting the calc mode to manual | |
wb.Settings.FormulaSettings.CalculationMode = CalcModeType.Manual; | |
wb.Save(dataDir + "output_out.xlsx"); | |
// Save to pdf | |
wb.Save(dataDir + "output_out.pdf"); |