Class CalculationData

Class CalculationData

Namespace: Aspose.Cells
Assembly: Aspose.Cells.dll (25.2.0)

Represents the required data when calculating one function, such as function name, parameters, …etc.

public class CalculationData

Inheritance

objectCalculationData

Inherited Members

object.GetType(), object.MemberwiseClone(), object.ToString(), object.Equals(object?), object.Equals(object?, object?), object.ReferenceEquals(object?, object?), object.GetHashCode()

Remarks

All objects provided by this class are for “read” purpose only. User should not change any data in the Workbook during the formula calculation process, Otherwise unexpected result or Exception may be caused.

Properties

CalculatedValue

Gets or sets the calculated value for this function.

public object CalculatedValue { get; set; }

Property Value

object

Remarks

User should set this property in his custom calculation engine for those functions the engine supports, and the set value will be returned when getting this property later. The set value may be of possible types of Aspose.Cells.Cell.Value, or array of such kind of values, or a Range, Name, ReferredArea. Getting this property before setting value to it will make the function be calculated by the default calculation engine of Aspose.Cells and then the calculated value will be returned(generally it should be #NAME? for user-defined functions).

Cell

Gets the Cell object where the function is in.

public Cell Cell { get; }

Property Value

Cell

Remarks

When calculating a formula without setting it to a cell, such as by Aspose.Cells.Worksheet.CalculateFormula(System.String,Aspose.Cells.CalculationOptions), the formula will be calculated just like it has been set to cell A1, so both Aspose.Cells.CalculationData.CellRow and Aspose.Cells.CalculationData.CellColumn are 0. However, cell A1 in the worksheet may has not been instantiated. So for such kind of situation this property will be null.

CellColumn

Gets the column index of the cell where the function is in.

public int CellColumn { get; }

Property Value

int

CellRow

Gets the row index of the cell where the function is in.

public int CellRow { get; }

Property Value

int

FunctionName

Gets the function name to be calculated.

public string FunctionName { get; }

Property Value

string

ParamCount

Gets the count of parameters

public int ParamCount { get; }

Property Value

int

Workbook

Gets the Workbook object where the function is in.

public Workbook Workbook { get; }

Property Value

Workbook

Worksheet

Gets the Worksheet object where the function is in.

public Worksheet Worksheet { get; }

Property Value

Worksheet

Methods

GetParamText(int)

Gets the literal text of the parameter at given index.

public string GetParamText(int index)

Parameters

index int

index of the parameter(0 based)

Returns

string

literal text of the parameter

GetParamValue(int)

Gets the represented value object of the parameter at given index.

public object GetParamValue(int index)

Parameters

index int

The index of the parameter(0 based)

Returns

object

The calculated value of the parameter.

Remarks

For one parameter:

If it is plain value, then returns the plain value itself;

If it is reference, then returns ReferredArea object;

If it references to dataset(s) with multiple values, then returns array of objects;

If it is some kind of expression that needs to be calculated, then it will be calculated in value mode and generally a single value will be returned according to current cell base. For example, if one parameter of D2's formula is A:A+B:B, then A2+B2 will be calculated and returned. However, if this parameter has been specified as array mode (by Aspose.Cells.Workbook.UpdateCustomFunctionDefinition(Aspose.Cells.CustomFunctionDefinition) or Aspose.Cells.FormulaParseOptions.CustomFunctionDefinition), then an array(object[][]) will be returned whose items are A1+B1,A2+B2,....

GetParamValueInArrayMode(int, int, int)

Gets the value(s) of the parameter at given index. If the parameter is some kind of expression that needs to be calculated, then it will be calculated in array mode.

public object[][] GetParamValueInArrayMode(int index, int maxRowCount, int maxColumnCount)

Parameters

index int

The index of the parameter(0 based)

maxRowCount int

The row count limit for the returned array. If it is non-positive or greater than the actual row count, then actual row count will be used.

maxColumnCount int

The column count limit for the returned array. If it is non-positive or greater than the actual row count, then actual column count will be used.

Returns

object[][]

An array which contains all items represented by the specified parameter.

Remarks

For an expression that needs to be calculated, taking A:A+B:B as an example: In value mode it will be calculated to a single value according to current cell base. But in array mode, all values of A1+B1,A2+B2,A3+B3,… will be calculated and used to construct the returned array. And for such kind of situation, it is better to specify the limit for the row/column count (such as according to Aspose.Cells.Cells.MaxDataRow and Aspose.Cells.Cells.MaxDataColumn), otherwise the returned large array may increase memory cost with large amount of useless data.