Usando la función ICustomFunction
Este artículo proporciona una comprensión detallada de cómo usar la función ICustomFunction para implementar funciones personalizadas con las API de Aspose.Cells.
La interfaz ICustomFunction permite agregar funciones de cálculo de fórmulas personalizadas para extender el motor de cálculo básico de Aspose.Cells para satisfacer ciertos requisitos. Esta función es útil para definir funciones personalizadas en un archivo de plantilla o en código, donde la función personalizada puede ser implementada y evaluada utilizando las API de Aspose.Cells como cualquier otra función predeterminada de Microsoft Excel.
Ten en cuenta que esta interfaz ha sido reemplazada por AbstractCalculationEngine y será eliminada en el futuro. Algunos artículos/ejemplos técnicos sobre la nueva API: aquí y aquí
Creación y evaluación de una función definida por el usuario
Este artículo demuestra la implementación de la interfaz ICustomFunction para escribir una función personalizada y usarla en la hoja de cálculo para obtener los resultados. Definiremos una función personalizada llamada MyFunc que aceptará 2 parámetros con los detalles siguientes.
- El primer parámetro se refiere a una sola celda
- El segundo parámetro se refiere a un rango de celdas
La función personalizada sumará todos los valores del rango de celdas especificado como segundo parámetro y dividirá el resultado por el valor del primer parámetro.
Así es como hemos implementado el método CalculateCustomFunction.
Así es como se utiliza la función recién definida en una hoja de cálculo
Visión general
Las API de Aspose.Cells simplemente colocan el objeto ReferredArea en la “paramsList” cuando el parámetro correspondiente es una referencia o su resultado calculado es una referencia. Si necesita la referencia en sí, puede usar directamente ReferredArea. Si necesita obtener el valor de una sola celda de la referencia correspondiente con la posición de la fórmula, puede usar el método ReferredArea.GetValue(filaOffset, int colOffset). Si necesita un array de valores de celda para toda el área, entonces puede usar ReferredArea.GetValues método.
Como las API de Aspose.Cells dan ReferredArea en “paramsList”, la ReferredAreaCollection en “contextObjects” ya no será necesaria (en las versiones antiguas no siempre podía dar un mapeo uno a uno a los parámetros de la función personalizada) por lo tanto se ha eliminado de los “contextObjects”.
public object CalculateCustomFunction(string functionName, ArrayList paramsList, ArrayList contextObjects)
{
...
object o = paramsList[i];
if(o is ReferredArea) //fetch data from reference
{
ReferredArea ra = (ReferredArea)o;
if(ra.IsArea)
{
o = ra.GetValues();
}
else
{
o = ra.GetValue(0, 0);
}
}
if (o is Array)
{
...
}
else if...
...
}